Altiris Inventory Solution 6.1 for Windows Reference
Transcription
Altiris Inventory Solution 6.1 for Windows Reference
ALTIRIS® INVENTORY SOLUTION® 6.1 FOR WINDOWS REFERENCE Notice Copyright © 1999-2005 Altiris Inc. All rights reserved. Product Version: 6.1 Document Date: February 25, 2005 Bootworks U.S. Patent No. 5,764,593. RapiDeploy U.S. Patent No. 6,144,992. Recovery Solution U.S. Patent No. 5,778,395, 5,907,672, 4701745, 5016009, 5146221, 5144425, 5463390, 5506580, 5532694, GB 2172127, B 904359, 3606869. Other patents pending. Due to the inherently complex nature of computer software, Altiris does not warrant that the Altiris software is error-free, will operate without interruption, is compatible with all equipment and software configurations, or will otherwise meet your needs. The content of this documentation is furnished for informational use only, is subject to change without notice, and should not be construed as a commitment by Altiris. Altiris, Inc. assumes no responsibility or liability for any errors or inaccuracies that may appear in this documentation. For the latest documentation, visit our Web site at www.altiris.com. Altiris, the Altiris logo, BootWorks, Inventory Solution, LabExpert, PC Transplant, RapiDeploy, and RapidInstall are registered trademarks of Altiris, Inc. in the United States and in other countries. Carbon Copy is a registered trademark licensed to Altiris, Inc. in the United States and a trademark of Altiris, Inc. in other countries. Altiris eXpress, Altiris Protect, Application Management Solution, Application Metering Solution, Asset Control Solution, Asset Management Suite, Client Management Suite, Compliance Toolkit, Connector Solution, Conflict Analysis Solution, Contract Management Solution, Deployment Server, Deployment Solution, Energy Saver Toolkit, Education Management Suite, Helpdesk Solution Software, Lab Management Suite, Migration Toolkit, Mobile Client for SMS, Monitor Solution, Notification Server, Patch Management Solution, Problem Management Suite, Recovery Solution, Server Management Suite, Site Monitor Solution, Software Delivery Solution, TCO Management Solution, UNIX Client for SMS, Web Administrator for SMS, Web Reports, and other product names are trademarks of Altiris, Inc. in the United States and other countries. Microsoft, Windows, and the Windows logo are trademarks, or registered trademarks of Microsoft Corporation in the United States and/or other countries. HP and Compaq are registered trademarks of the Hewlett-Packard Corporation. Dell is a registered trademark of Dell Inc. Macintosh is a registered trademark of the Apple Computer Corporation. Palm OS is a registered trademark of Palm Computing, Inc. BlackBerry is a service mark and a trademark of Research In Motion Limited Corporation. RIM is a service mark and trademark of Research In Motion (RIM). All other brand names are trademarks or registered trademarks of their respective companies. Inventory Solution for Windows Reference 2 Contents Inventory Solution® 6.1 for Windows Altiris® Reference Notice . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2 Getting Started . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6 Chapter 1: Introduction to Inventory Solution . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Ease of Use and Deployment . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Inventory Scan Agents ........................................................... SMS Integration ................................................................ 8 9 9 9 Chapter 2: Installation. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 Installing Notification Server . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 Installing Inventory Solution . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 Installing the Altiris Agent . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 Uninstalling Inventory Solution Registration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 Chapter 3: Quick Start Tasks . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 Running Inventory Solution with Altiris Agents . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 Manually Scanning Inventory using AeXInvSoln.exe . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 Running Inventory Solution using HTTP (without the Altiris Agent Installed) . . . . . . . . . . . . . . . . . . . . 14 Running Inventory Solution using a Network File Share (without the Altiris Agent Installed) . . . . . . . . 14 Performing a Software Scan . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 Performing a Hardware Scan . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 Editing the AuditPls.ini file . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 Viewing Inventory Scan Results . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 Using Inventory Solution . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18 Chapter 4: Running Inventory Solution. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 Running Inventory Solution with the Altiris Agent . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20 Running Inventory Solution without the Altiris Agent . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21 Running AeXInvSoln.exe using a Logon Script . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21 Setting Up a Web Page or E-mail to Run Inventory Solution . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23 Disabling the File Compare Feature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24 Alternate Directory for NSI File Creation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24 Input and Output Command Line Arguments . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25 Controlling Data Output Format . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25 Security Context Considerations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25 Inventory Solution for Windows Reference 3 Contents Real Time View Inventory Results . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26 Deploying and Collecting Inventory Solution Data . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26 Customizing Data Reported by Inventory Solution . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27 Customizing How Data is Reported to a Notification Server . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28 Inventory Collector . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28 Reports . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29 Managing Patches . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29 Running Inventory Solution using HTTP, E-mail Deployment, or a File Server . . . . . . . . . . . . . . . . . . . 29 Web Inventory Package . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 Package Editor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31 Network File Access . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34 Running Inventory Solution Using Floppy Disks . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34 Logon Script Agent Deployment . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35 Frequency of Scan . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35 Necessary Files . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36 Using SMS to Deploy and Collect Inventory Solution Data . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36 Create a Source Directory with Required Files . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36 Remove Agent Data From an SMS 2.0 Database . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41 Configuration File . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42 Windows Schedules . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43 Chapter 5: Troubleshooting . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44 How to Use Inventory Solution with a Port Other Than 80 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44 How to Post Inventory Solution Data Using HTTP with Web and E-mail Attachments Timeouts Posting Data from Remote Computers Log Files . . . . . . . . . . . . . 44 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45 Inventory Solution Data Flow . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46 DLL Requirements when using Windows 95 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47 Agents. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48 Software Audit Agent . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49 Software Audit Agent Overview ...................................................... Features and Benefits of the Software Audit Agent .................................... Input for the Software Audit Agent ................................................. Customizing Audit Configuration .................................................. audit.rul File Usage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Files Needed to Run the Software Audit Agent ....................................... Running the Software Audit Agent Using Logon Scripts ................................ How the Software Audit Agent Works .............................................. 49 49 50 50 51 51 51 52 Software Audit Agent Configuration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Modifying the Software Audit Agent Configuration File ................................. Scanning for a Single File or Files of a Given Extension ................................ Using the Software Audit Agent Configuration Editor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Advanced Tab ............................................................. Directories Tab . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Disk Usage Tab ............................................................ Include Unknown Tab ....................................................... Exclusion Filters Tab ........................................................ 54 54 55 56 57 58 59 59 59 Inventory Solution for Windows Reference 4 Contents File Masks Tab . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Known As Tab ............................................................. Manufacturer Known As Tab .................................................. Overrides Tab ............................................................. Special Groups Tab . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61 61 62 62 63 Software Audit Agent Troubleshooting ................................................. How to Scan For Data (XLS, DOC, PPT, QWB, etc.) Files .............................. How to Use the Software Audit Agent Through a Logon Script for Windows 95/98 . . . . . . . . . . . . How to Find Just One File With the Software Audit Agent . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . How to Handle Win32 Files when the Software Audit Agent does not Currently Read the Version Resource Information . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66 66 66 67 68 Custom Inventory Agent. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69 Custom Inventory Agent Administration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69 Custom Inventory Agent Command Line Arguments . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69 XML File Syntax and Examples . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 70 Exchange Agent . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82 How the Exchange Agent Works . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82 Exchange Agent Configuration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82 Customizing the Data Reported . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82 Exchange Agent Administration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83 Exchange Agent Troubleshooting . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84 Serial Number Agent . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85 Serial Number Agent Administration Serial Number Agent Troubleshooting . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85 Machine Inventory Agent . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 86 Reference . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 87 Appendix A: Exchange Directory Values . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 88 Appendix B: Program Command Line Arguments. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 95 AeXAuditpls Executable . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 95 AeXCustInv Executable . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 96 AeXExchPls Executable . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97 AeXInvSoln Executable . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 98 AeXMachInv Executable . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99 AeXNSInvCollector Executable AeXRunControl Executable AeXSNPlus Executable . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 102 Appendix C: Inventory Solution Data Reference . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 105 Index . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 108 Inventory Solution for Windows Reference 5 Getting Started Welcome to the Altiris Inventory Solution for Windows, a complete reference manual and administration guide for Inventory Solution. Quick Links “Introduction to Inventory Solution” on page 7 Provides an introduction to Inventory Solution. “Installation” on page 11 Install Inventory Solution on your Notification Server. “Quick Start Tasks” on page 13 Provides common tasks to familiarize you with Inventory Solution. Inventory Solution for Windows Reference 6 Chapter 1: Introduction to Inventory Solution Altiris Inventory Solution is designed to meet the demands of today's diverse network environments. It gathers comprehensive software and hardware data from virtually any computer running a Windows 32-bit Operating System. A variety of deployment and data collection options ensure that Inventory Solution works in any environment (including native integration for Microsoft Systems Management Server (SMS)). To help maximize your investment, Inventory Solution goes beyond simple data gathering. By providing a Web-based management console, policies to alert you of critical information, and professional quality Web reports, Inventory Solution includes the tools you need to transform your inventory data into useful information. Inventory Solution provides comprehensive inventory for Windows computers including serial number, hardware inventory, software audit inventory, and user/contact information (with Exchange profile). Inventory Solution also: • Supports zero-footprint configuration. • Operates in always connected, sometimes connected and standalone (through floppy) computing environments. Inventory Solution for Windows Reference 7 Chapter 1: Introduction to Inventory Solution • Can be installed to run on a recurring basis in conjunction with the Altiris Agent. The information that is gathered from the computers is the same regardless of whether or not you use the zero footprint option. Note: Altiris provides Inventory Solution to use with UNIX, Palm, Pocket PC, and Apple Macintosh. For more information, see the Altiris Web site. Quick Link • “Overview” on page 8 Overview Inventory Solution lets you take inventory of any Windows computer. Inventory Solution runs with zero footprint - nothing has to be installed on the computer, or it can be run through your Altiris Agent. It can be run from the network, and it even fits on two floppy disks so you can inventory computers that are not on the network. Features and Benefits Inventory Solution provides these features and benefits. • • Works with computers with no IP connectivity A floppy disk method has been designed for these non-networked Windows workstations. See “Running Inventory Solution Using Floppy Disks” on page 34. Provides full access to all the data from any browser Data can be accessed through Reports on Notification Server. • Includes integrated Reports Inventory Solution comes with numerous built-in reports that help you analyze and make proactive management decisions based upon Inventory Solution data. This allows quick and easy access to inventory information without having to create custom SQL scripts. Custom reports may also be added and scheduled to run automatically. • Posts data through files and HTTP Inventory Solution data can be sent to Notification Server through a file placed in the nscap\evtinbox folder or through an HTTP post to Altiris/NS/ postevent.asp. • Deploys through e-mail, URL, login scripts Inventory Solution can be deployed through e- mail, a URL, login scripts, or any other method you have in place to run a program on the target computers. Inventory Solution data includes • PC Serial Number and BIOS details • Comprehensive software auditing • Disk, operating system, and system configuration settings • Registry settings • Full end user information (with Microsoft Exchange profiles) • WMI objects Inventory Solution data can be posted to Notification Server by creating a file on a network share, by posting the data directly using HTTP, or it can submit the data to the Altiris Agent and let the Altiris Agent post the data to the Notification Server. Quick Links • “Ease of Use and Deployment” on page 9 • “Inventory Scan Agents” on page 9 • “SMS Integration” on page 9 Inventory Solution for Windows Reference 8 Chapter 1: Introduction to Inventory Solution Ease of Use and Deployment A special emphasis has been placed on ease of deployment, small agent size, and non-intrusive operation (by using unused CPU and network resources). Inventory Solution can be deployed to a target computer in multiple ways. The method you should use depends upon your particular needs. The deployment methods are: • Logon Script • E-mail (as a link or attachment) • Web link • Floppy disk • Manual (through shared or mapped drive) • Altiris Agent Inventory Scan Agents Inventory Solution includes several inventory scan agents that determine what data will be collected in the inventory scan. The inventory scan agents can be found in the AeXInvSoln.ini file. The default AeXInvSoln.ini file is shown below: aexauditpls.exe /hidden /output xml aexmachinv.exe aexcustinv.exe /in .\AeXCustInvStd.cit /out AeXCustInvStd.nsi aexexchpls.exe /hidden /output xml aexsnplus.exe /output xml aexnsinvcollector.exe /hidden /o ..\..\..\EvtInbox Software Scan (aexauditpls.exe) – Runs a detailed scan of the software installed on the computer. It uses the auditpls.ini file to control how applications are reported. There are several powerful and flexible configuration options available in setting up your auditpls.ini file. For more information, see “Software Audit Agent” on page 49. Hardware Scan (aexmachinv.exe) – This is the hardware scanning agent for Inventory Solution. It reports hardware data such as the operating system, the logged on user, the set of local and network disks, the amount of physical memory, the TCP/IP configuration, CPU, and PCMCIA devices. For more information, see “Machine Inventory Agent” on page 86. Custom Scan (aexcustinv.exe) – This agent gathers data from the registry, WMI, or INI files using scripts to let you customize the set of data reported. For more information, see “Custom Inventory Agent” on page 69. Exchange User Data Scan (aexexchpls.exe) – Reports data about the logged on user as found in the Microsoft Exchange Directory Service. For more information, see “Exchange Agent” on page 82. Serial Number Scan (aexsnpls.exe) – Gathers serial number, computer make and model, BIOS, and memory module information. For more information, see “Serial Number Agent” on page 85. Inventory Collector (aexnsinvcollector.exe) – Collects and consolidates all the data that each scan agent found during the scan. The scan data is consolidated and sent to Notification Server. For more information, see “Customizing How Data is Reported to a Notification Server” on page 28. SMS Integration Inventory Solution is fully compatible with SMS 2003. Inventory Solution is tightly integrated with Microsoft Systems Management Server (SMS). Inventory Solution comes with Package Definition Files that make it a very simple process to deploy the Inventory Solution package as an SMS package. Inventory Solution for Windows Reference 9 Chapter 1: Introduction to Inventory Solution Inventory agents report data to SMS using the industry standard MIF file format. SMS maintains history information on changes that are reported by the Inventory agent. This lets you see what has changed over time on your computers. Inventory Solution lets you track in the SMS database computers that are not SMS clients. The Serial Number, Software Audit, and Exchange Agents can create a MIF on the SMS client’s NOIDMIF directory or XML data can be passed to the Notification Server and SMS data forwarding can create a native SMS MIF. See “Using SMS to Deploy and Collect Inventory Solution Data” on page 36. Inventory Solution for Windows Reference 10 Chapter 2: Installation Inventory Solution 6.1 is designed to work with Notification Server 6.0 or later. It is recommended that you install the latest version of Notification Server. Notification Server must be installed before installing Inventory Solution. The following Windows computers are supported by Inventory Solution • Windows 32-bit computers: • Windows 95 • Windows 98 • Windows Me • Windows NT 4 • Windows 2000 • Windows XP • Windows 2003 Inventory Solution Prerequisite • Microsoft Internet Explorer 4.01 or later - This installs DLL files needed by Inventory Solution. (If you are running Inventory Solution on a Windows 95 computer, see “DLL Requirements when using Windows 95” on page 47.) Quick Links • “Installing Notification Server” on page 11 • “Installing Inventory Solution” on page 11 • “Installing the Altiris Agent” on page 12 • “Uninstalling Inventory Solution” on page 12 • “Registration” on page 12 Installing Notification Server Before you can install Inventory Solution, you must have an operational Notification Server running. For information on installing Notification Server, see “Installation” in the Altiris Notification Server Help. Installing Inventory Solution To install Inventory Solution to a previously installed Notification Server (with or without licenses) 1 Click Start > Programs > Altiris > Notification Server > Altiris Console to start the Altiris Console. 2 Click the Configuration tab. 3 In the treeview pane, click on Upgrade/Install Additional Solutions. Inventory Solution for Windows Reference 11 Chapter 2: Installation 4 Click the Available Solutions tab. 5 Click the Solutions button. 6 Select Altiris Inventory Solution for Windows. 7 Click Start. This installs Inventory Solution to the Notification Server. Installing the Altiris Agent If you want to run Inventory Solution with Altiris Agents, you must first deploy the Altiris Agent to your computers. For information on installing the Altiris Agent, see “Altiris Agent Installation” in the Altiris Notification Server Help. Uninstalling Inventory Solution To uninstall Inventory Solution 1 Click Start > Programs > Altiris > Notification Server > Altiris Management Console to start the Altiris Console. 2 Click the Configuration tab. 3 Click on Upgrade/Install Additional Solutions. 4 Click the Currently Installed tab. 5 Click the Remove button next to Inventory Solution. 6 Click Start. Registration Each Altiris product comes with a 7-day trial license that is installed by default. You can register and obtain a 30-day evaluation license through our Web site at www.altiris.com or purchase a full product license. To view your current license, open the Altiris Console, click the Configuration tab, and select Licensing. For more information, see “Licensing Altiris Software” in the Altiris Getting Started Guide on the product CD or on our Web site at www.altiris.com/support/documentation. Inventory Solution for Windows Reference 12 Chapter 3: Quick Start Tasks This section contains instructions for the tasks used most often in Inventory Solution. Quick Start Tasks assume that the needed software is installed, configured, and set up (see “Installation” on page 11). Quick Links • “Running Inventory Solution with Altiris Agents” on page 13 • “Manually Scanning Inventory using AeXInvSoln.exe” on page 13 • “Running Inventory Solution using HTTP (without the Altiris Agent Installed)” on page 14 • “Running Inventory Solution using a Network File Share (without the Altiris Agent Installed)” on page 14 • “Performing a Software Scan” on page 14 • “Performing a Hardware Scan” on page 15 • “Editing the AuditPls.ini file” on page 15 • “Viewing Inventory Scan Results” on page 17 Running Inventory Solution with Altiris Agents Inventory Solution provides Inventory Tasks that let you run inventory on Altiris-enabled computers. When one or more of these tasks are enabled, an Inventory Solution package containing the necessary files to run Inventory Solution automatically gets sent to all Altiris Agents that the Notification Server communicates with. These Inventory Tasks are disabled by default. When you enable these tasks, they will be sent to all computers in the All Windows Computers collection (by default). To view the Inventory Tasks 1 2 From the Altiris Console, select the Tasks tab. In the treeview pane, navigate to Tasks > Assets and Inventory > Inventory > Windows > Inventory Tasks. For information on these tasks, see “Deploying and Collecting Inventory Solution Data” on page 26. Manually Scanning Inventory using AeXInvSoln.exe 1 On the target computer, run AeXInvSoln.exe from the install path\Altiris\Notification Server\NSCap\Bin\Win32\X86 folder on the Notification Server computer. An inventory scan is initiated based on the default AeXInvSoln.ini file. The Inventory Scan program closes automatically when the scan has completed. Inventory Solution for Windows Reference 13 Chapter 3: Quick Start Tasks To View Inventory Scan Results View the results of your inventory scan in the Altiris Console using the Resource Manager. 1 In the Altiris Console, click the Resources tab. 2 In the treeview pane, navigate to Resource Management > Collections > Computer Collections > All Computers. 3 Double-click the name of the computer on which you ran the manual scan. This opens a Resource Manager window in a separate browser. 4 In the Resource Manager, click the Summaries and Inventory tabs to view data from your scan. Running Inventory Solution using HTTP (without the Altiris Agent Installed) 1 E-mail the following URL to the target set of computers and instruct the users to either download the file and then install it on their local computers or select “Open this file from its current location” to install the file without downloading it: http://NSName/Altiris/NS/NSCAP/Bin/Win32/X86/AeXWebInvPkg.exe where NSName is the name of your Notification Server. For more information on the Web Inventory Package (AeXWebInvPkg.exe), see “Web Inventory Package” on page 30. Running Inventory Solution using a Network File Share (without the Altiris Agent Installed) You have two choices for running Inventory Solution using a Network File Share. 1 Use the Notification Server computer nscap share. a Make sure that the users of your target computers have access to the following nscap share on the Notification Server: install path\Altiris\Notification Server\NSCap b 2 Have the users of the target computers run the self extracting NSCap\Bin\Win32\X86\Inventory Solution\AeXWebInvPkg.exe file from the Notification Server computer. Use another file server. a Copy the self extracting AeXWebInvPkg.exe file to another file server (another Windows NT server in another LAN or domain, NetWare, UNIX, and so forth) that the target computers can connect to and have the users of the target computers run the self extracting AeXWebInvPkg.exe file from this server. Note: The self extracting AeXWebInvPkg.exe file is found in the install path\Altiris\Notification Server\NSCap\Bin\Win32\X86 directory. For more information on the Web Inventory Package (AeXWebInvPkg.exe), see “Web Inventory Package” on page 30. Performing a Software Scan To perform a complete inventory scan, including a hardware and software scan 1 On the target computer, run AeXInvSoln.exe from the install path\Altiris\Notification Server\NSCap\Bin\Win32\X86 folder on the Notification Server computer. An inventory scan is initiated based on the default AeXInvSoln.ini file. The Inventory Scan program closes automatically when the scan has completed. Inventory Solution for Windows Reference 14 Chapter 3: Quick Start Tasks To perform only a software scan 1 On the target computer, run AeXAuditPls.exe from the install path\Altiris\Notification Server\NSCap\Bin\Win32\X86 folder on the Notification Server computer. To perform a hidden software scan with XML output 1 Run the following from the Command Prompt. aexauditpls.exe /hidden /output xml To edit the auditpls.ini file 1 Run AeXAPedit.exe from the install path\Altiris\Notification Server\NSCap\Bin\Win32\X86 folder on the Notification Server computer. 2 Click File > Open. 3 Select the auditpls.ini file, then click Open. See Also • “Software Audit Agent” on page 49 • “AeXAuditpls Executable” on page 95 • “Editing the AuditPls.ini file” on page 15 Performing a Hardware Scan To perform a complete inventory scan, including a hardware and software scan 1 On the target computer, run AeXInvSoln.exe from the install path\Altiris\Notification Server\NSCap\Bin\Win32\X86 folder on the Notification Server computer. An inventory scan is initiated based on the default AeXInvSoln.ini file. The Inventory Scan program closes automatically when the scan has completed. To perform only a hardware scan 1 On the target computer, run AeXMachInv.exe from the install path\Altiris\Notification Server\NSCap\Bin\Win32\X86 folder on the Notification Server computer. See Also • “Machine Inventory Agent” on page 86 • “AeXMachInv Executable” on page 99 Editing the AuditPls.ini file This section show you how to use the Audit Plus Configuration Editor to modify the AuditPls.ini file. It gives you an example of how to add specific programs that can be included in the software scan. You can then use this example to edit your AuditPls.ini the way you want. Note: The following should be completed from the Notification Server computer (install path\Program Files\Altiris\Notification Server\NSCap\Bin\Win32\X86). 1 In the X86 folder, make a backup copy of the AuditPls.ini file and place it on your desktop for safekeeping. 2 In the X86 folder, double-click on the AeXAPedit.exe file. The Audit Plus Configuration Editor opens. 3 In the Audit Plus Configuration Editor, select File > Open and open the AuditPls.ini file (from the X86 folder). 4 Under the File Masks tab, enter *.dll in the File Mask field and click Add. Inventory Solution for Windows Reference 15 Chapter 3: Quick Start Tasks 5 Under the Disk Usage tab, enter zip in the Extensions field and click Add. 6 Under the Special Groups tab, click Add. 7 Enter a GUID (Globally Unique Identifier) for this Special Group. Generate a new GUID using a utility like guidgen.exe and copy the same GUID for the GUID value. 8 In the New Special Group dialog, enter AeX SW ACME in the Name field. 9 Enter ACME|Engineering|1.0 in the Class field. 10 Make sure Filename is selected in the Attribute field and add the following three attribute values: 11 12 13 a Enter sol.exe and click Add. b Enter freecell.exe and click Add. c Enter winmine.exe and click Add. In the Attribute field, select Internal Name and add the following three attribute values: a Enter sol.exe and click Add. b Enter freecell and click Add. c Enter winmine and click Add. Click OK. Under the Known As tab, enter sol.exe in the Internal name field and Solitaire in the Known field, and click Add. as 14 Repeat step 13 for winmine (Minesweeper) and freecell (Freecell). 15 Under the Overrides tab, click Add to open the Override Properties dialog box. 16 Under the A file with this property... column, enter sol.exe in the Filename field. 17 Under the ...is to be overridden with this property column, enter Solitaire in the Product name field. 18 Click OK. 19 Repeat step 15 through step 18 for Freecell and Minesweeper. 20 In the Audit Plus Configuration Editor click File > Save to save changes to the AuditPls.ini file. 21 Close the Audit Plus Configuration Editor. 22 Test the new auditpls.ini file by manually running the AexInvSoln.exe in the X86 directory to be sure that it picks up the file you want and reports it into inventory. You can tell it works because the inventory under this server explorer drill-down will have that change in it. 23 Copy the new auditpls.ini file in the X86 directory to the distribution directory. The auditpls.ini file that gets distributed with the inventory policies is located in install path\Program Files\Altiris\Notification Server\nscap\bin\win32\X86\Inventory Solution. 24 Update the distribution point. To do this, open the Altiris Console, click the Resources tab, and navigate in the treeview pane to Resource Management > Resources > Defaults > Package. In the content pane, double-click on the package (Inventory Agent Package). When the package window appears, click the Update Distribution Points button. This will force Notification Server to verify the contents of the Inventory Agent package. 25 In the X86 directory on the Notification Server computer, double-click the AeXInvSoln.exe file to run a new inventory scan. When your Altiris Agent requests a new configuration, it will know that something in the package has changed and download your new auditpls.ini file and run with that. See Also • “Viewing Inventory Scan Results” on page 17 Inventory Solution for Windows Reference 16 Chapter 3: Quick Start Tasks Viewing Inventory Scan Results This section tells you how to view modified inventory results that are generated by changes to the AuditPls.ini configuration file. Note: The changes listed here were discussed in “Editing the AuditPls.ini file” on page 15 (adding Freecell, Solitaire, and Minesweeper programs and EXE, DLL, and ZIP extensions to get inventory for). 1 In the Altiris Console, click the Resources tab. 2 In the treeview pane, navigate to Resource Management > Collections > Computer Collections > All Computers. 3 In the All Computers collection, double-click the name of the computer on which you ran the scan. This opens a (or refreshes a currently open) Resource Manager window in a separate browser. 4 In the Resource Manager, click the Inventory tab. 5 In the treeview pane, navigate to Data Classes > Inventory > Software and then click AeX SW ACME and verify that Freecell, Solitaire, and Minesweeper are listed. Note: If the computer on which the scan was run does not have the Freecell, Solitaire, or Minesweeper game installed, the AeX SW ACME table will not appear. 6 Click AeX SW Audit Software and verify that the list contains both EXE and DLL files. (You will need to scroll all the way to the right to view extensions in the list.) 7 Click AeX SW Disk Usage and verify that ZIP files are included in the list. Inventory Solution for Windows Reference 17 Using Inventory Solution This section provides information about using Inventory Solution. Quick Links “Running Inventory Solution” on Provides a comprehensive guide for running page 19 Inventory Solution. “Troubleshooting” on page 44 Inventory Solution for Windows Reference Provides troubleshooting information. 18 Chapter 4: Running Inventory Solution Inventory Solution consists of a number of programs that can be run on Windows 9x/Me/NT/2000/ XP/2003 computers. There are a number of ways to run Inventory Solution • Run Inventory Solution on an Altiris-enabled computer. The computers that run Inventory Solution through the Altiris Agent will report back inventory results independent of any user action. • Run Inventory Solution in a zero footprint mode (without the Altiris Agent being installed) through a mechanism like a logon script, a Web URL, or using floppy disks. This provides an easy way to gather full detailed inventory without having to install an agent that is continually running on your target computers. • Use another software distribution system like Altiris Deployment Server or Microsoft SMS to run the program. • E-mail distribution and collection (as a link or an attachment) • SMS package • Manually (through a shared or mapped drive) Each of the programs that are run as part of Inventory Solution have various command line parameters that control various features of the product. The following programs are part of Inventory Solution • AeXInvSoln - Controls the serialized execution of all the other programs based upon a configuration file. It also generates a GUID, which is stored in the registry. • AeXNSInvCollector - The Inventory Collector consolidates the data from the various NSI files and posts the data to Notification Server using an NSE file or through an HTTP post. It includes a GUID in the header of the NSE file. • AeXSNPlus, AeXAuditpls, AeXExchpls, AeXMachInv, AeXCustInv - Generate XML formatted NSI files that contain the data about the computer that was scanned. (See “Agents” on page 48.) • Various utilities and files aid in running logon scripts, e-mail attachments, SMS advertisements, and customizing the inventory reported. Each of the executable files can be run with a /? command line argument to see the full details on the command line options. The Inventory Collector program that comes with Inventory Solution does a comparison of the current inventory scan with the last scan. Only those NSI files that have changes since data was last reported to the Notification Server are sent to the Notification Server. This feature works independent of how you deploy Inventory Solution. You get delta history file management (which results in less traffic being sent to your Notification Server) when running Inventory Solution with the Altiris Agent, with logon scripts, or with Web or e-mail. (See “Inventory Collector” on page 28.) The deployment reports that come with Inventory Solution help you track new computers that have been discovered as well as computers that are no longer updating inventory within a given amount of time. Inventory Solution for Windows Reference 19 Chapter 4: Running Inventory Solution Running Inventory Solution with the Altiris Agent Quick Links • “Running Inventory Solution with the Altiris Agent” on page 20 • “Running Inventory Solution without the Altiris Agent” on page 21 • “Disabling the File Compare Feature” on page 24 • “Alternate Directory for NSI File Creation” on page 24 • “Input and Output Command Line Arguments” on page 25 • “Controlling Data Output Format” on page 25 • “Security Context Considerations” on page 25 • “Real Time View” on page 26 • “Inventory Results” on page 26 • “Deploying and Collecting Inventory Solution Data” on page 26 • “Customizing Data Reported by Inventory Solution” on page 27 • “Customizing How Data is Reported to a Notification Server” on page 28 • “Reports” on page 29 • “Managing Patches” on page 29 • “Running Inventory Solution using HTTP, E-mail Deployment, or a File Server” on page 29 • “Web Inventory Package” on page 30 • “Network File Access” on page 34 • “Running Inventory Solution Using Floppy Disks” on page 34 • “Logon Script Agent Deployment” on page 35 • “Using SMS to Deploy and Collect Inventory Solution Data” on page 36 • “Configuration File” on page 42 • “Windows Schedules” on page 43 Running Inventory Solution with the Altiris Agent When you install Inventory Solution, it automatically creates a package and five policies that will cause the inventory agents to run on all Windows computers that have the Altiris Agent installed. After the policies are enabled, the Inventory Solution software will then be downloaded and installed on all Altiris Agents that are attached to your Notification Server. The five policies are set up so that • Software audit, serial number, and machine inventory is run on a monthly schedule. • End-user and exchange inventory is run on a monthly schedule. • Software is scanned once a week. • Hardware is scanned once a day. • User details are scanned once a day. You can change the schedule of the policies for your own environment. You can also change the collection that each policy applies to. For example, you can make distinct inventory policies for servers and other policies for workstations by changing which collection the policies apply to. The data that is collected from the computer when Inventory Solution is run from the context of the Altiris Agent is the same data that is collected when Inventory Solution is run in a standalone mode. Note: Running Inventory Solution with the Altiris Agent allows you to see which user is the primary user on the target computer. Login events are only generated by the basic inventory sent by the Altiris Agent. For more information on how to get primary user information from the Altiris Agent, see “Primary User Inventory Class” in the Altiris Notification Server Help. Inventory Solution for Windows Reference 20 Chapter 4: Running Inventory Solution Running Inventory Solution without the Altiris Agent Nobody has to be logged onto the computer for the updated inventory data to be collected and posted to Notification Server. See the Altiris Software Delivery Solution Help for details on how the Inventory Solution software is installed as a package onto a computer with the Altiris Agent installed. The files that are installed onto the target computers are in the install path\Altiris\Notification Server\NSCap\Bin\Win32\X86\Inventory Solution folder. This folder is automatically set up as the package distribution point for Windows computers to which you want the Inventory Solution agent installed. Running Inventory Solution without the Altiris Agent Inventory Solution can also be run independent of the Altiris Agent. The files that are in the install path\Altiris\Notification Server\NSCap\Bin\Win32\X86 folder are designed to be run directly off the nscap share on the server by any Windows computer. (The difference in the files between the X86 and the Inventory Solution directories is the settings in the configuration files. The executable files are the same). Inventory Solution can be run by any Windows computer from the Notification Server computer. No additional software needs to be preinstalled to capture the inventory data. To run the Inventory Solution agents on a target Windows computer 1 On the target computer, run AeXInvSoln.exe from the install path\Altiris\Notification Server\NSCap\Bin\Win32\X86 folder on the Notification Server computer. For a listing of AeXInvSoln.exe command line arguments, see “AeXInvSoln Executable” on page 98. The inventory scan is performed on the target computer and the data is posted to the Notification Server. Note: AeXInvSoln.exe can be set to run through hyperlink in an e-mail. Quick Links • “Running AeXInvSoln.exe using a Logon Script” on page 21 • “Setting Up a Web Page or E-mail to Run Inventory Solution” on page 23 Running AeXInvSoln.exe using a Logon Script The Inventory Solution agents can be set to run using a logon script. Inventory Solution for Windows Reference 21 Chapter 4: Running Inventory Solution Running Inventory Solution without the Altiris Agent You can schedule Inventory Solution to run through a logon script so that it doesn't execute every time there is a logon. This can be done using a supplied program called AeXRunControl in one of two ways - run on a set schedule or run on a random schedule. Look for AeXRunControl.exe in the install path\Altiris\Notification Server\NSCap\Bin\Win32\X86 folder. It is installed as part of Inventory Solution. (For argument information, see “AeXRunControl Executable” on page 101.) Run on a Set Schedule Run as: AeXRunControl.exe “Inventory Solution” 48 install path\Altiris\notification server\nscap\bin\win32\x86\AeXInvSoln.exe /useHKCU Details: • The first parameter (in this case the first parameter is “Inventory Solution”) identifies the control check. This is used as the identifying registry value for when this command was last run. This is stored under HKLM\SOFTWARE\Altiris\Notification Server\RunControl (example: Inventory Solution : 1/18/00 20:30:13). • The second parameter (in this case, the second parameter is 48) is the number of hours between running (example: 48 = 2 days). Example: If AeXRunControl is called again within 48 hours with the same command line, it will not execute. • The third parameter (example “install path\Altiris\notification server \nscap\bin\win32\x86\AeXInvSoln.exe”) is the command to execute if it passes the timing check, such as it hasn't run within 48 hours. So AeXRunControl.exe “Inventory Solution” 48 “install path\Altiris\notification server\nscap\bin\win32\x86\AeXInvSoln.exe” would check to see if you've tried to run a command identified as “Inventory Solution” within the last 48 hours. If not, then it would execute the command “install path\Altiris\notification server\nscap\bin\win32\x86\AeXInvSoln.exe”. Of course “install path\Altiris\notification server\nscap\bin\win32\x86\AeXInvSoln.exe” needs to be replaced with the actual command to be executed (which would usually have / hidden as one of the parameters). The point is that if you need to pass parameters, then the whole command needs to be included within quotes (“”). • The fourth parameter, /useHKCU, is for environments where the user does not have permissions to write to HKLM but they can write to the current user registry. Run on a Random Schedule Run as: AeXRunControl.exe /rndschedule “Inventory Solution” install path\Altiris \notification server\nscap\bin\win32\x86\AeXInvSoln.exe WEEKLY 1 5 / useHKCU /now Details: • The first parameter, /rndschedule, signifies the use of the format that supports the randomized schedule. • The second parameter (in this case the second parameter is “Inventory Solution”) identifies the control check. This is used as the identifying registry value for when this command was last run. This is stored under HKLM\SOFTWARE\Altiris\Notification Server\RunControl (example: Inventory Solution : 1/18/00 20:30:13). Inventory Solution for Windows Reference 22 Chapter 4: Running Inventory Solution Running Inventory Solution without the Altiris Agent • The third parameter (example “install path\Altiris\notification server\nscap\bin\win32\x86\AeXInvSoln.exe”) is the command to execute. • The fourth parameter is the string WEEKLY, which denotes the time period of the schedule. • The fifth and sixth parameters (1 and 5) are the lower and upper bounds for the randomly generated day of the week (restricted to 1-7). Weekdays are: 1 = Sunday, 2 = Monday, etc. • The seventh parameter, /useHKCU, is for environments where the user does not have permissions to write to HKLM but they can write to the current user registry. • The eighth parameter, /now, causes the program to execute immediately if this is the first time the CommandLine program is run. Using AeXRunControl.exe in the AeXInvSoln INI file You can also use AeXInvSoln.exe to run the agents using AeXRunControl.exe. This allows greater flexibility in running AeXRunControl.exe such as letting you choose different times for each agent to run. For example: AeXRunControl.exe “Software Audit” 12 “aexauditpls.exe /hidden /output xml” /useHKCU AeXRunControl.exe “Machine Inventory” 24 aexmachinv.exe /useHKCU AeXRunControl.exe “Custom Inventory” 36 “aexcustinv.exe /in .\AeXCustInvStd.cit /out AeXCustInvStd.nsi” /useHKCU AeXRunControl.exe “Exchange Plus” 48 “aexexchpls.exe /hidden /output xml” /useHKCU AeXRunControl.exe “SN Plus” 60 “aexsnplus.exe /output xml” /useHKCU AeXRunControl.exe “NS Inventory Collector” 73 “aexnsinvcollector.exe / hidden /o ..\..\..\EvtInbox” /useHKCU Clean Before Run Mode To remove the resulting data from previous scans 1 Use the /cleanbeforerun command in AeXInvSoln.exe. The /cleanbeforerun command cleans the install path\Altiris\express\Inventory folder before AeXInvSoln.exe runs. Clean After Run Mode AeXInvSoln.exe can be run in clean after run mode by using the /cleanafterrun flag. Clean after run mode removes any NSI files that are created from the local computer after the scan. Setting Up a Web Page or E-mail to Run Inventory Solution Here are two ways to run Inventory Solution without using the Altiris Agent. Running From a Web URL or an E-mail Attachment 1 For Web URL: Point your Web browser to http://NSName/NSCap/Bin/Win32/X86/ AeXWebInvPkg.exe. Instruct users to choose “Run” when prompted. 2 For E-mail: E-mail the self-extracting AeXWebInvPkg.exe file to the target set of computers and instruct the users to run the attached file. Or E-mail the Web URL (above) of the self-extracting AeXWebInvPkg.exe file to the target set of computers and instruct the users to run the file. Inventory Solution for Windows Reference 23 Chapter 4: Running Inventory Solution Disabling the File Compare Feature Creating a Web Page to Run Inventory Solution 1 Copy the following text into a blank Notepad file, replace NSName with the name of your Notification Server, and then save the file as win32inv.htm in the install path\Altiris\Notification Server folder. <html> <head> <meta http-equiv=”Content-Type” content=”text/html”> <title>Altiris Inventory Solution</title> </head> <body> <p> <a href=”http://NSName/Altiris/NS/NSCap/Bin/Win32/X86/ AeXWebInvPkg.exe”>Inventory</a> - Click here to run Win32 Inventory Solution on a target computer. </p> </body> </html> 2 Browse to http://NSName/Altiris/NS/win32inv.htm and click on the link. When prompted if you want to Run or Save, select Run. (Note: Nothing is actually installed; this only runs Inventory Solution). Disabling the File Compare Feature You can disable the file compare feature by using the /nocheck command in AeXNSInvCollector.exe. When you use this argument, all the data is sent from the target computer to the Notification Server. If you are posting data to a new Notification Server, you would want to use this argument. History is not kept on a Notification Server basis but on the target computer as a whole. Note: This is also known as Delta Data transfer. Alternate Directory for NSI File Creation Inventory Solution can be modified to place the output NSI files on any directory on your target computers. The default location used for the placement of the NSI file is install path\Altiris\express\Inventory. Each of the programs that run as part of Inventory Solution can run with a command line argument that will cause them to place the NSI files in any directory. If you have set up security on your workstations so that users do not have write permissions on this default directory or if you want to place the NSI files in another location on the hard drive, use the following example file to change the output directory. Sample AeXInvSoln.ini File AeXInvSoln.exe uses a file to indicate the sets of agents to run as part of Inventory Solution. This file needs to be modified to contain the proper command line arguments to redirect the output of the agents to a designated directory. IMPORTANT: The command line arguments on the agents are case sensitive in some cases. The following sample AeXInvSoln.ini file causes the agents to place the output in C:\temp and post the data to a Notification Server called targhee through an HTTP post. AeXSNPlus.exe /o c:\temp AeXMachinv.exe /o c:\temp\diskinv.nsi AeXauditpls.exe /hidden /o %TEMP% /output both AeXexchpls.exe /hidden /o c:\temp AeXNSInvCollector.exe /hidden /url “http://targhee/Altiris/NS/ postevent.asp” /s c:\temp Note: Instead of using c:\temp, you can use an environment variable such as %TEMP% (if the agents cannot write to the provided directory, the default is %TEMP%). AeXInvSoln.exe will expand any environment variables (surrounded by % %) that are listed in the AeXInvSoln.ini file. Inventory Solution for Windows Reference 24 Chapter 4: Running Inventory Solution Input and Output Command Line Arguments Input and Output Command Line Arguments Command line arguments can be used to specify the location of output and input files. To specify the output location of the files created by Inventory Solution, use the /o outputpath argument. Be sure to use this path as the source path for the collector. This can be specified with the /s inputpath argument after the call to AeXNSInvCollector.exe. aexauditpls.exe /hidden /output xml /o outputpath aexmachinv.exe /output xml /o outputpath aexexchpls.exe /hidden /output xml /o outputpath aexsnplus.exe /output xml /o outputpath aexnsinvcollector.exe /hidden /s inputpath /o NSEOutputpath To override the default output location for the collector, use the /o argument as in the example above, and the NSE output file will be placed in the folder specified. For example, the /o argument may be used if the default location install path\Altiris\express\Inventory is not accessible. Controlling Data Output Format Inventory Solution lets you specify whether the data output is in XML that the Notification Server processes or SMS MIF format. The following are some of the advantages of doing XML with Notification Server vs. SMS MIFs only: • Notification Server can handle a higher frequency of inventory record updating. • You can replicate to SMS from Notification Server on a schedule based upon SMS settings. High frequency updates for Notification Server does not mean high frequency data loads to SMS. (SMS is slower than Notification Server in loading data). Use the /output mif argument if you want the SMS client to collect inventory data during its scheduled hardware inventory cycle. The one disadvantage to this is that the MIFs in the SMS client’s NOIDMIFS directory will be collected every SMS hardware inventory scan regardless of whether or not the data has changed. This process would add Inventory Solution data directly to SMS through the SMS client and the inventory agent that is run with the /output mif argument (AeXAuditpls.exe, AeXSNPlus.exe, and AeXExchpls.exe only). To get XML only output, run the agent with the /output xml command line argument. Security Context Considerations By default, Inventory Solution NSI files are created in install path\Altiris\express\Inventory. • If you are running Inventory Solution from the context of the Altiris Agent, then the Altiris Agent will have the security context to create these directories. • If you are running Inventory Solution on a locked down Windows NT or Windows 2000 computer and running the program under the local logged on user’s security context, the user may not have permission to create the NSI files in that directory. • All of the agents that are part of Inventory Solution will redirect their NSI output files to a directory using the user’s temp directory if the NSI file is unable to be created under the Program Files folder. Suppose you want to deploy Inventory Solution using logon scripts and a number of your computers are Windows 2000. Also suppose the users on those computers do not have the access rights to create new files and directories under install path\Altiris\Inventory. In this case, the Inventory Solution agents will place the NSI files under the user’s temp space. Note: If another user logs onto the computer and has their profile set up so that they have a different temp directory, the NSI files will go into that new temp directory. This is not an error condition. It simply means that you may not benefit from all the local history processing that a target computer can perform to send up the minimal set of inventory changes to Notification Server. Inventory Solution for Windows Reference 25 Chapter 4: Running Inventory Solution Real Time View Note: If the scan is run from a security context that does not have any read permissions in the user profile data, then default data of Jan 1 1900 and a size of 0 is used in the AeX OS User Profiles group. However, you can still see that the profile has been loaded on that computer. For more details on how to place the NSI files in another directory, see “Alternate Directory for NSI File Creation” on page 24. Real Time View An application, AexNSIViewer6Plus, which can view any NSI file in real time. These can be NSIs reported by basic inventory or by custom inventory. This program is found in the install path\Altiris\Notification Server\NSCap\Bin\Win32\X86 directory. Note: NSI files in an older Inventory format (Inventory Solution 6.0 and older) are not supported by AexNSIViewer6Plus. This includes any data class sent by Basic Inventory, identified by the prefix AeX_AC. To view these older NSI files, use AeXNSIViewer. AeXNSIViewer provided the same functionality as AexNSIViewer6Plus in Inventory Solution 6.0 and older. Inventory Results You can access inventory results through the Resource Manager. In the Inventory tab, there is a group in the Data Classes > Inventory > Software folder called AeX AC Inventory Results. This gives you the collection time, the file count, the total size, and the version (the version of collector posting the data). Deploying and Collecting Inventory Solution Data When you install Inventory Solution, it automatically creates a package and five policies that, when enabled, cause the inventory agents to run on all Windows computers that have the Altiris Agent installed. The Inventory Solution software will be downloaded and installed on all Altiris Agents that are attached to your Notification Server. These policies are: • Recreate Full Inventory This policy is used to run software audit, serial number, and machine inventory on a monthly schedule. It sends all inventory data to the Notification Server regardless of whether or not the inventory has changed since the last run. This is particularly useful if you have set up your Notification Server to forward inventory to another Notification Server. If you use this policy, your history files will be deleted from your Notification Server. This will let the target Notification Server receive the full inventory. • Recreate User Inventory This policy is used to run end-user and exchange inventory on a monthly schedule. It sends all inventory data to the Notification Server regardless of whether or not the inventory has changed since the last run. This is particularly useful if you have set up your Notification Server to forward inventory to another Notification Server. If you use this policy, your history files will be deleted from your Notification Server. This will let the target Notification Server receive the full inventory. • Hardware Inventory • Software Inventory • User Inventory These policies are found by clicking on the Tasks tab, then navigating to Tasks > Assets and Inventory > Inventory > Windows > Inventory Tasks in the treeview pane. These policies all use the Inventory Client package. Inventory Solution for Windows Reference 26 Chapter 4: Running Inventory Solution Customizing Data Reported by Inventory Solution For more information on running these with the Altiris Agent, see “Running Inventory Solution with the Altiris Agent” on page 20. Customizing Data Reported by Inventory Solution Inventory Solution uses a number of executable modules to scan for specific types of information and post the data to Notification Server. (The AeXAuditpls, AeXExchpls, and AeXSNPlus agents can directly generate MIF files on SMS client computers.) Inventory Solution agents generate output files with an extension of NSI (Notification Server Inventory). NSI files contain inventory data in an XML format. The default output folder used by the agents when creating an NSI file is install path\Altiris\express\Inventory. The folder used can be customized with command line arguments to the various Inventory Solution agents. To do this, use the /o outputpath argument. AeXInvSoln.exe executes the programs that are listed in the AeXInvSoln.ini file sequentially. Each of the various agents have command line arguments. You can run each application with a /? command argument for a usage dialogue that provides the full command line usage details. The Inventory Solution agents are described in the following table. AeXSNPlus The AeXSNPlus program gathers serial number, computer make and model, BIOS, SMBIOS, and memory module information. It can generate both MIF as well as NSI files. For full details on how to customize the set of data reported by the serial number agent, see “Serial Number Agent” on page 85. AeXMachInv The AeXMachInv program runs on any Windows 32-bit Intel based computer. It reports data from the core Win32 API such as the operating system, the logged on user, the set of local and network disks, the amount of physical memory, TCP/IP, CPU, and PCMCIA devices. There are options to run AeXMachInv.exe with the /zfp argument which will cause the agent to not report memory and disk change history. The /zfp argument will also remove the GUID from the registry. Then, the next time Inventory Solution is run, a new GUID will be generated and the computer will appear as a new computer in the database. You can also specify which inventory groups to include or exclude from the output of AeXMachInv.exe. For details on this agent, see “Machine Inventory Agent” on page 86. AeXAuditpls The AeXAuditpls program runs a detailed scan of the hard drive reporting on the applications that are present on the computer. It also reports on data file usage. It uses the auditpls.ini file to control how applications are reported. AeXAuditpls.exe can generate both MIF and NSI files. There are a large amount of configuration options in setting up your auditpls.ini file. For the full details on how to customize the software scan data, see “Software Audit Agent” on page 49. AeXExchpls The AeXExchpls program reports data about the logged on user as found in the Microsoft Exchange Directory Service, Active Directory, or Exchange 2000. It uses the exchpls.ini file to control which user properties are reported from the Microsoft Exchange Directory Service. AeXExchpls.exe can generate both MIF and NSI files. To learn how to customize the data reported from AeXExchpls.exe, see “Exchange Agent” on page 82. AeXCustInv The AeXCustInv program lets you gather arbitrary registry and WMI data. For details on how to use AeXCustInv.exe, see “Custom Inventory Agent” on page 69. Sample VB Form A sample VB application shows how you can have any application register data with Inventory Solution and report to the database. For details, see the Altiris Resource Kit. The Altiris Resource Kit also outlines the NSI file format information. AeXNSInvCollector The AeXNSInvCollector program posts the data collected to the Notification Server. It is used to consolidate the data from the various NSI files into a single Notification Server Event (NSE) file and post the data to the Notification Server using HTTP, e-mail deployment, floppy disks, or a file server. Inventory Solution for Windows Reference 27 Chapter 4: Running Inventory Solution Customizing How Data is Reported to a Notification Server Customizing How Data is Reported to a Notification Server The Inventory Collector is used to post the inventory data collected to the Notification Server. It is used to consolidate the data from various NSI files into a single NSE file and post the data to the Notification Server using HTTP, e-mail deployment, or a file server. Notification Server Inventory AeXSNPlus Creates NSI File NSI AeXExchpls Creates NSI File NSI AeXMachInv Creates NSI File NSI AeXAuditpls Creates NSI File NSI Any Custom Inventory Creates NSI File Creator NSI GUID AeXNSInvCollector NSE Floppy Notification Server File Server Email HTTP AeXNSInvCollector combines all NSI files, places them into a newly created NSE file, and places the GUID (taken from the registry) in the header. AeXNSInvCollector can then post directly to the NS using HTTP, email, floppy disk, or to the Altiris Agent queue. Quick Link • “Inventory Collector” on page 28 Inventory Collector For a listing of the Inventory Collector command line arguments, see “AeXNSInvCollector Executable” on page 99. To run the Inventory Collector from another NT, NetWare or UNIX Server 1 Copy the self extracting AeXWebInvPkg.exe file to your target server(s). (See “Running Inventory Solution using HTTP, E-mail Deployment, or a File Server” on page 29.) 2 Run AeXWebInvPkg.exe. There are several ways to do this. Some of them are: • Run AeXRunControl.exe with its parameters to limit frequency. Inventory Solution for Windows Reference 28 Chapter 4: Running Inventory Solution • Run AeXWebInvPkg.exe in a login script on a local Novell server mapped drive. • Run AeXWebInvPkg.exe using a Web link on a local Web server. Reports To run the Inventory Collector from a Web URL or an e-mail attachment 1 Complete one of the following steps depending on whether you are using a Web URL or an e-mail attachment: a Post the self extracting AeXWebInvPkg.exe file to a Web URL (by default, this program is located at http://NSName/Altiris/NS/NSCAP/Bin/Win32/X86/AeXWebInvPkg.exe). Instruct users to either download the file and then install it on their local computers or select “Open this file from its current location” to install the file without downloading it. b E-mail the self extracting AeXWebInvPkg.exe file to the target set of computers and instruct the users to run the attached file. c To reduce the impact on the e-mail server, you can e-mail a link to the Web location used in step a. Reports Inventory Solution utilizes Notification Server to produce and host Reports. You can generate and view reports from within the Altiris Console. The deployment reports help you understand which computers are new, which ones are no longer reporting current information, and the size of the inventory data being transmitted over the network. The other reports provide details about the inventory data that is gathered. Managing Patches Inventory Solution provides reports that let you find out which computers have received OS updates and which have not. These reports can be found in the Altiris Console under the Reports tab by navigating to Reports > Assets and Inventory > Inventory > Windows > OS Updates in the treeview pane. These reports are • Count of Win9X Computers without Update ‘X’ • Count of WinNT/2000 Computers without Update ‘X’ • Distinct Win9X Updates by Computer • Distinct WinNT/2000 Updates by Computer To use these reports 1 In the treeview pane, click on a report to select it. 2 In the content pane, click Run this Report. 3 Select the Hotfix or Machine Name from the drop-down list. 4 Click Refresh. 5 You can drill down to see more data on the table items by double-clicking on the item name. Running Inventory Solution using HTTP, E-mail Deployment, or a File Server Inventory Solution can be run as a self extracting executable that your users can execute (“Web Inventory Package” on page 30). This self extracting executable does not require the Altiris Agent to be loaded on the target computer. Inventory Solution for Windows Reference 29 Chapter 4: Running Inventory Solution Web Inventory Package There are three ways to use Inventory Solution • Altiris Agent - Load the Altiris Agent on the target computer (see “Running Inventory Solution with the Altiris Agent” on page 20). Advantages to using: • • Local system access to computer • Logon and User trail • Runs on a schedule • Restartable posting of data (mobile user friendly) • Delta-file reduction of posted data HTTP - Send the Inventory Solution files (using the Web Inventory Package) via HTTP to the target computer (see “To run the Inventory Collector from a Web URL or an e-mail attachment” on page 29). Advantages to using: • • No need for security validation • No connection via MS Networking required • Works through proxy servers and firewalls • No Altiris Agent needed • Zero Footprint Network File Path (UNC) - Let the target computer user access the Inventory Solution files from a network path. You can use either the Web Inventory Package or point the user directly to the Inventory Solution directory (see “To run the Inventory Collector from another NT, NetWare or UNIX Server” on page 28 or “Network File Access” on page 34). Advantages to using: • Inclusion of login scripts, email, etc. • Security via MS Networking or Active Directory (not everyone can run and post) • No Altiris Agent needed • Zero Footprint Inventory Solution data can be easily posted to Notification Server using HTTP. This allows computers that are not able to connect to the Notification Server nscap share (because of security, network transport, or other issues) to still post the data over an HTTP connection to Notification Server. HTTP posting uses the settings that are defined in Internet Explorer to determine the user of proxy servers for HTTP traffic. Notification Server includes an Active Server Page URL (http://NSName/Altiris/NS/ postevent.asp) that is able to accept data and insert it into the Notification Server database. (This is the same URL that is used by UNIX computers that post UNIX Inventory Solution data to Notification Server.) In order to post data through HTTP, the target computer must have Internet Explorer 4.01 SP1 or later installed on the computer. Web Inventory Package During installation of Inventory Solution, a self executing executable (Web Inventory Package) gets created. This executable is found at install path\Altiris\Notification Server\NSCap\Bin\Win32\X86\AeXWebInvPkg.exe. As the Web Inventory Package is being created, the name of the Notification Server that it is being created on is placed in the INI file. This means that the Web Inventory Package will only work with the Notification Server that it came from. If you want to use this package on another Notification Server, you need to modify the package using the Package Editor. Inventory Solution for Windows Reference 30 Chapter 4: Running Inventory Solution Web Inventory Package The Web Inventory Package contains all Inventory Solution files needed to run an inventory on a target computer. It lets you run inventory on computers that do not have the Altiris Agent installed. A Package Editor is provided that lets you edit the Web Inventory Package. See “Package Editor” on page 31. The Web Inventory Package can be distributed the following ways: • E-mail - see “To run the Inventory Collector from a Web URL or an e-mail attachment” on page 29. • Web URL - see “To run the Inventory Collector from a Web URL or an e-mail attachment” on page 29. • Network File Path - see “To run the Inventory Collector from another NT, NetWare or UNIX Server” on page 28. When run on the target computer, the Web Inventory Package does the following: • Extracts the Inventory Solution files to the target directory. • Runs AeXInvSoln.exe (the default options are /s AeXIsHttp.ini /cleanbeforerun /hidden). For information on AeXInvSoln.exe, see “Running Inventory Solution without the Altiris Agent” on page 21 and “AeXInvSoln Executable” on page 98. Package Editor The Package Editor lets you edit the Web Inventory Package (AeXWebInvPkg.exe). It is found in the same directory as the Web Inventory Package - install path\Altiris\Notification Server\NSCap\Bin\Win32\X86. Note: Before you edit the Web Inventory Package, it is recommended that you make a copy of it. Upon saving the package, a copy of the original package is stored with a .bak extension. To edit the Web Inventory Package 1 Find AeXPkgEditor.exe (found in the directory listed above) and run it. 2 Select the Web Inventory Package (AeXWebInvPkg) and click Open. 3 Edit the desired fields, then click Save. Inventory Solution for Windows Reference 31 Chapter 4: Running Inventory Solution Web Inventory Package To edit a file in the Web Inventory Package 1 Run AeXPkgEditor.exe. 2 Click the Files tab. 3 Click the file to edit from the Files in Package list. 4 Click Extract. 5 Select the location to extract the file to, then click OK. 6 Edit the file in the editor of your choice. 7 Click the file that you edited from the Files in Package list. 8 Click Delete. 9 Click Yes. 10 Click Add. 11 Navigate to the file you edited and select it. 12 Click Open. 13 Click Save. Inventory Solution for Windows Reference 32 Chapter 4: Running Inventory Solution Web Inventory Package Options Tab Items Item Command Line Description The command line for AeXInvSoln.exe. The default command line is: AeXInvSoln.exe /s AeXIsHttp.ini /cleanbeforerun /hidden Note: AeXIsHttp.ini can be edited in the AeXIsHttp.ini file contents field. See “AeXInvSoln Executable” on page 98. Extract files silently Use this field to list the folder to extract the Inventory Solution files to. to folder The default is %TEMP%. Note: If the checkbox for this field is cleared, the files will be installed to the default (%TEMP%). To list another folder besides the default: 1) Click the checkbox. 2) Enter the desired folder. Prompt user with message Lets you prompt the user with a message before continuing with running AeXInvSoln.exe. Note: The prompt needs to be ended with a question like “Do you want to continue?”. The prompt gives two buttons: Yes and No. The user clicks Yes to continue with the install, and No to abort the install. AeXIsHttp.ini file contents This field lets you change the contents of the AeXIsHttp.ini file that gets placed in the Web Inventory Package. AeXInvSoln.exe uses this INI file to run inventory on the target computer. See Also “AeXAuditpls Executable” on page 95 “AeXMachInv Executable” on page 99 “AeXExchPls Executable” on page 97 “AeXSNPlus Executable” on page 102 “AeXNSInvCollector Executable” on page 99 Save Click to save all changes. Cancel Click to cancel all changes. Files Tab Items Item Description Files in Package Lists all the files found in the Web Inventory Package. Add Click to add a file to the Web Inventory Package. Extract Lets you extract a file from the Web Inventory Package so you can edit it. To extract a file 1) Click a file in the Files in Package list. 2) Click Extract. 3) Select the location to extract to, then click OK. Inventory Solution for Windows Reference 33 Chapter 4: Running Inventory Solution Network File Access Files Tab Items Item Description Delete Lets you delete a file from the Web Inventory Package. To delete a file 1) Click a file in the Files in Package list. 2) Click Delete. 3) Click Yes. Save Click to save all changes. Cancel Click to cancel all changes. Network File Access You can run Inventory Solution from the nscap share on Notification Server and post the data to Notification Server using HTTP. However there are some cases where the target computers may not be able to connect a network drive to Notification Server. For example, dial-up or remote target computers may not have a fast enough connection, or Novell NetWare target computers may not be able to connect to the Notification Server file system. There are three primary ways to run Inventory Solution on computers that are not able to connect to the Notification Server file system: • Copy the Inventory Solution files to another file server (another Windows NT server in another LAN or domain, NetWare, UNIX, and so forth) that the computers can connect to and have the target computers run the Inventory Solution files from this server. Note: The Inventory Solution files are found in the install path\Altiris\Notification Server\NSCap\Bin\Win32\X86\Inventory Solution directory. • Access the self extracting AeXWebInvPkg.exe file from a URL. (See “To run the Inventory Collector from a Web URL or an e-mail attachment” on page 29.) Note: This self extracting executable automatically points to the Notification Server that it comes from. • E-mail the self extracting AeXWebInvPkg.exe file to users of target computers. (See “To run the Inventory Collector from a Web URL or an e-mail attachment” on page 29.) Running Inventory Solution Using Floppy Disks A floppy disk based Inventory Solution can be used to gather inventory from remote computers. You need three blank formatted floppy disks. Two for the programs and one for the data. To create the Inventory Solution Floppy disks 1 Insert a blank formatted floppy disk in the A: drive. 2 Copy the file win32invfloppy1.exe from the install path\Altiris\Notification Server\NSCap\Bin\Win32\X86\floppy folder to the floppy disk. Note: In the floppy folder, there is a readme.txt file that contains these instructions. 3 Label the Disk Inventory Program Disk 1. 4 Insert another blank formatted floppy disk in the A: drive. 5 Copy the file win32invfloppy2.exe from the install path\Altiris\Notification Server\NSCap\Bin\Win32\X86\floppy folder to the floppy disk. 6 Label the Disk Inventory Program Disk 2. 7 Label a third blank formatted disk Inventory Data Disk. Inventory Solution for Windows Reference 34 Chapter 4: Running Inventory Solution Logon Script Agent Deployment To perform an inventory scan of a stand alone computer Win32invfloppy1.exe runs the Software Audit, Exchange, Machine Inventory, and Custom Inventory agents. Win32invfloppy2.exe runs the Serial Number agent. Note: The first time you perform an inventory scan on a stand alone computer, you must run Win32invfloppy1.exe before you run Win32invfloppy2.exe. The agents that run on Win32invfloppy1.exe create a record for that stand alone computer in the Notification database. If you only run Win32invfloppy2.exe the first time you perform an inventory scan on a stand alone computer, the data that the Serial Number agent collects cannot be placed in the Notification Database because it will have no record for that computer. After you have performed an inventory scan on a stand alone computer using Win32invfloppy1.exe, you can use either Win32invfloppy1.exe or Win32invfloppy2.exe (or both) on subsequent scans. 1 Click Start > Run and enter A:\win32invfloppy1.exe and click OK. This could take some time to run from the floppy disk depending on floppy disk speed. 2 Click Start > Run and enter A:\win32invfloppy2.exe and click OK. This could take some time to run from the floppy disk depending on floppy disk speed. 3 After the inventory program has completed, it will try to write the inventory data back to the floppy disk. If there is not enough space on the floppy disk or if the floppy disk is write protected, you will be prompted to put in another floppy disk. Use the Inventory Data Disk. A file with the extension of NSE will be created on the floppy disk. To post inventory data to Notification Server 1 Insert the Inventory Data Disk in the floppy disk drive of a networked computer and execute A:\postinv.bat with the following parameter: postinv.bat NSName where NSName is the name of your Notification Server. Logon Script Agent Deployment Inventory Solution can readily be deployed to target computers through the use of logon scripts. The file logonscript.bat is included in the install path\Altiris\Notification Server\NSCap\Bin\Win32\x86 folder when you install Inventory Solution on your Notification Server. Quick Links • “Frequency of Scan” on page 35 • “Necessary Files” on page 36 Frequency of Scan Typically, you will want to limit the frequency at which the scan is run on a computer. The following logon script (logonscript.bat) will limit the scan to run no more frequently than once a week (168 hours) @Echo Rem Rem Rem Rem Rem - off This is a sample logon script batch file that will run the Inventory Solution Agent every 7 days. The AeXRunControl.exe file limits the frequency at which the called program will be executed. Rem - The parameters are AeXRunControl <key> <Number of Hours> Rem - <Command Line> Rem Rem Rem Rem - <Key> is an arbitrary name for a key that will be created in the registry that maintains the history of when the command was last run. The Key is created under Rem - HKLM\Software\Altiris\Run Control. Rem - <Number of Hours> limits the frequency at which the command Inventory Solution for Windows Reference 35 Chapter 4: Running Inventory Solution Using SMS to Deploy and Collect Inventory Solution Data Rem - line will be executed. Rem - <Command Line> is the program to be run. The path is Rem - relative to the location from where Rem - AeXRunControl is executed. AeXRunControl InvSoln 168 aexinvsoln.exe The program AeXRunControl.exe is included in Inventory Solution (see “AeXRunControl Executable” on page 101). Adjust the Number of Hours parameter to adjust the maximum frequency at which AeXInvSoln will be executed. Note: To use AeXInvSoln.exe command line parameters with AeXRunControl.exe, you must place the command line in quotes. For example: AeXRunControl InvSoln 168 “aexinvsoln.exe /hidden” Necessary Files If you want to run Inventory Solution from your logon server share point (netlogon) instead of the nscap share on your Notification Server, copy the Inventory Solution files to the logon server(s). These files are found in the install path\Altiris\Notification Server\NSCap\Bin\Win32\x86\Inventory Solution directory. Example 1: AeXNSInvCollector /v MYSERVER Sends the Inventory Solution data to the location \myserver\nscap\evtinbox as a file. The user must be able to connect to Notification Server and create a file in this directory. Example 2: AeXNSInvCollector /url “http://myserver/Altiris/NS/postevent.asp” Sends the data to Notification Server through HTTP. No security context of the user is required as this is an anonymous HTTP post. Using SMS to Deploy and Collect Inventory Solution Data Inventory agents report data to SMS using the industry standard MIF file format. For SMS 2.0, the MIF file is placed in the WinDir\MS\SMS\NOIDMIFS directory. If this directory does not exist, no MIF is written. Quick Link • “Create a Source Directory with Required Files” on page 36 • “Remove Agent Data From an SMS 2.0 Database” on page 41 Create a Source Directory with Required Files The following tasks show how to create an SMS package source directory, and provide an example SMS PDF/SMS (Package Definition File) used to create an SMS package. These tasks show the deploying of Inventory Solution to SMS clients with the following Inventory Solution data configuration: • Audit • Serial Number • Exchange The following task shows how Inventory Solution can be configured to produce SMS NOIDMIF's only. These NOIDMIF's will then be collected during the SMS clients regular hardware inventory cycle. Inventory Solution for Windows Reference 36 Chapter 4: Running Inventory Solution Using SMS to Deploy and Collect Inventory Solution Data To create a source directory with required files 1 From the command line, run mifonly.bat. This is found in the install path\Altiris\Notification Server\NSCap\Bin\Win32\X86 folder. This will create a Mifonly directory and populate it with all of the required files for creating an SMS package source directory. The directory includes a PDF and SMS file for creating the SMS package (PDF for SMS 1.2/SMS for SMS 2.0). The source directory is about 1.5 MB. To view or edit the AeXISMif.ini file The AeXISMif.ini file is used with AeXInvSoln.exe to specify how the individual agents will run. Each agent has additional arguments that may be used to customize how it runs. Note: To use an INI other than the default AeXInvSoln.ini, use the /s argument as in the following example: Example: AeXInvSoln.exe /s AeXISMif.ini 1 Open the AeXISMif.ini in a text editor, such as Notepad. 2 Edit the file and close the text editor. To create an SMS Package from Definition 1 In the SMS Administrator Console, right-click on Packages and select New > Package from Definition. 2 Click Next in the Create Package from Definition Wizard. Inventory Solution for Windows Reference 37 Chapter 4: Running Inventory Solution Using SMS to Deploy and Collect Inventory Solution Data 3 Browse to install path\Altiris\Notification Server\NSCap\Bin\Win32\X86\Mifonly and select InvSoln.sms, then click Open. 4 Select Inventory Solution and click Next. 5 In the Source Files dialog, select Always obtain files from a source directory, and click Next. 6 Specify the source directory install path\Altiris\Notification Server\NSCap\Bin\Win32\X86\Mifonly, and click Next. 7 Click Finish. 8 Press the F5 key to refresh the SMS Administrator Console. Inventory Solution for Windows Reference 38 Chapter 4: Running Inventory Solution Using SMS to Deploy and Collect Inventory Solution Data To verify that you have the programs 1 Expand the Altiris Inventory Solution package. 2 Click Programs. You should see two programs: • Inventory Solution - Run Invisible • Inventory Solution - Run Visible To deploy package to distribution servers 1 Right-click Systems Management Server > Site Database > Packages > Inventory Solution > Distribution Points and select All Tasks > Manage Distribution Points. 2 In the Manage Distribution Points Wizards dialog box, verify that Copy the package to new distribution points is selected and click Next. 3 Click the check box to the left of the distribution server(s) that you wish to use and click Next. 4 Click Finish. Inventory Solution for Windows Reference 39 Chapter 4: Running Inventory Solution Using SMS to Deploy and Collect Inventory Solution Data To verify the target collection 1 Expand Collections and select All Windows NT Systems. 2 Verify that the collection contains the target Windows NT computers. To create advertisements 1 Right-click Systems Management Server > Site Database > Advertisements and select New > Advertisement. 2 Enter the Advertisement Properties and click OK. 3 Click on the Schedule tab and enter the Properties as appropriate for your environment and click OK. To check the package status 1 Right-click Systems Management Server > Site Database > System Status > Package Status and select Altiris Inventory Solution. 2 If necessary, press the F5 key to refresh the status. 3 In the right pane, verify that the package installed successfully. Inventory Solution for Windows Reference 40 Chapter 4: Running Inventory Solution Using SMS to Deploy and Collect Inventory Solution Data To check the advertisement status 1 Select Systems Management Server > Site Database > System Status > Advertisement Status and press the F5 key to refresh the results. This may take a little while to run on your target computers based on how SMS has been set up in your environment. Remove Agent Data From an SMS 2.0 Database In the BackOffice 4.5 resource kit, there is a tool to delete group classes. It is delgrp.exe. For the Delete Group Class tool to run correctly, it must be installed on an SMS primary site server. The installation is part of the BORK 4.5 installation. See the Readme.doc at the root of the BORK 4.5 CD to review the installation and operation instructions of this and other SMS tools. The syntax for the command is: delgrp “group” where “group” is the name of the Group Class from SMS SQL database. Obtain a list of the exact class names (which must be used, as well as the double quote marks around the name). 1 Run the following SQL query: select GroupClass from GroupMap Inventory Solution for Windows Reference 41 Chapter 4: Running Inventory Solution Configuration File 2 After making the query, make sure the DB box in the SQL Server Query Analyzer has the SMS database listed, and then click the green arrow button to execute the query bring up the results as shown below. 3 With the proper group name, execute the following command at the command prompt (Audit agent is used as the example): ..\delgrp.exe “ALTIRIS|AUDIT_SOFTWARE|1.0” (.. means the path to where ever the delgrp.exe is) for all of the groups that have been created by the Audit agent. This will delete the Group table and its contents from the site database. After doing this and allowing the database some time to refresh and stabilize (a few minutes or several hours depending on the activity of the server) it would probably be good to reset the site with the SMS Install program, but this is not required by the published instructions from Microsoft. Configuration File Inventory Solution uses several components to check for information about a Windows computer. The process is initiated by running AeXInvSoln.exe from the install path\Altiris\Notification Server\NSCap\Bin\Win32\X86 folder. AeXInvSoln.exe uses AeXInvSoln.ini for parameters that execute the individual inventory components. The default AeXInvSoln.ini is shown below: aexauditpls.exe /hidden /output xml aexmachinv.exe aexcustinv.exe /in .\AeXCustInvStd.cit /out AeXCustInvStd.nsi aexexchpls.exe /hidden /output xml aexsnplus.exe /output xml aexnsinvcollector.exe /hidden /o ..\..\..\EvtInbox Each of the above programs can be run with a /? command to identify available options. The AeXInvSoln.ini file is extendible, enabling administrators to call custom scripts or batch files as necessary. An example would be our AeXCustInv.exe agent, which lets you return custom inventory data from the registry, WMI, or from INI files. To run this agent as part of the inventory process, ensure that the AeXCustInv.exe (and any custom inventory scripts you may have created) is located in the same directory with the other agents you are using and then add AeXCustInv.exe / command line arguments as an entry in the INI file. Inventory Solution for Windows Reference 42 Chapter 4: Running Inventory Solution Windows Schedules Example 1 AeXAuditPls.exe /hidden AeXCustInv.exe /in AeXCustInv2.xml AeXNSInvCollector.exe /hidden /URL:http://NotificationServerName/Nscap/ postevent.asp You can also call a scripting host, command line, or batch file to perform other actions as necessary. For more details on AeXCustInv.exe and custom inventory scripts, see “Custom Inventory Agent Administration” on page 69. Another example is to use AeXInvSoln.exe to run the agents using AeXRunControl.exe. This allows greater flexibility in running AeXRunControl.exe such as letting you choose different times for each agent to run. Example 2 AeXRunControl.exe “Software Audit” 12 “aexauditpls.exe /hidden /output xml” /useHKCU AeXRunControl.exe “Machine Inventory” 24 aexmachinv.exe /useHKCU AeXRunControl.exe “Custom Inventory” 36 “aexcustinv.exe /in .\AeXCustInvStd.cit /out AeXCustInvStd.nsi” /useHKCU AeXRunControl.exe “Exchange Plus” 48 “aexexchpls.exe /hidden /output xml” /useHKCU AeXRunControl.exe “SN Plus” 60 “aexsnplus.exe /output xml” /useHKCU AeXRunControl.exe “NS Inventory Collector” 73 “aexnsinvcollector.exe / hidden /o ..\..\..\EvtInbox” /useHKCU Windows Schedules Notification Server creates several Windows schedules that can be used in your solutions. In addition, Inventory Solution creates one Windows schedule. You will find this schedule in the Windows Scheduled Tasks by clicking on Start > Settings > Control Panel > Scheduled Tasks. • NS.Modify VirtualMachine Item ResourceType - This Windows schedule is created to convert the resource type of a Virtual Machine resource from ‘Computer’ to ‘VirtualMachine’. It is enabled by default and is scheduled to run at 9:00 AM everyday, starting 1/1/2000. Inventory Solution for Windows Reference 43 Chapter 5: Troubleshooting This section lists common troubleshooting problems and gives probable resolutions. Quick Links • “How to Use Inventory Solution with a Port Other Than 80” on page 44 • “How to Post Inventory Solution Data Using HTTP with Web and E-mail Attachments” on page 44 • “Timeouts Posting Data from Remote Computers” on page 45 • “Log Files” on page 45 • “Inventory Solution Data Flow” on page 46 • “DLL Requirements when using Windows 95” on page 47 How to Use Inventory Solution with a Port Other Than 80 1 Configure your IIS server to support the monitoring of additional ports. a From Windows 2000, click Start > Programs > Administrative Tools > Internet Services Manager. b Double-click on the server name in the left pane. c Right-click Default Web Site and select Properties. d Select the Web Site tab. e Click Advanced. f Click Add. g In the TCP Port field, enter your desired port number. h Click OK. i Click OK. j Click OK. 2 Alter the Inventory Solution INI file (AeXInvSoln.ini). 3 Alter the AeXNSInvCollector.exe line so you are using the following URL format: http://server:port/Altiris/NS/postevent.asp Example: AeXNSInvCollector /url “http://myserver:80/Altiris/NS/postevent.asp” How to Post Inventory Solution Data Using HTTP with Web and E-mail Attachments See “Running Inventory Solution using HTTP, E-mail Deployment, or a File Server” on page 29 and “To run the Inventory Collector from a Web URL or an e-mail attachment” on page 29. Inventory Solution for Windows Reference 44 Chapter 5: Troubleshooting Timeouts Posting Data from Remote Computers When posting the data to Notification Server through HTTP (which happens when data is posted from the Altiris Agent or when you use the /URL argument with AeXNSInvCollector.exe) the data needs to be able to be posted within the active server page timeout period on your Notification Server. If your target computers experience problems posting the data before the timeout period, you can change the ASP timeout period. To change the timeout 1 Open the Internet Service Manager MMC console. 2 Expand the Default Web Site and select properties of the Altiris virtual directory. 3 From the Altiris properties, select the Configuration button in the Virtual Directory tab. 4 In the App Options tab change the ASP Script Timeout parameter to a higher number of seconds. Log Files Components that encounter errors when running place messages in a log file in the folder install path \Altiris\Notification Server\Logs. This is a text file in XML format that you can open in a text editor or within Internet Explorer to review the specific error messages. Inventory Solution for Windows Reference 45 Chapter 5: Troubleshooting Inventory Solution Data Flow The following figure shows the data flow for Inventory Solution. Description of the above graphic 1a - The Altiris Agent passes the data to the NSCap\EvtInbox directory. A thread created by the Altiris NS Receiver Service monitors the EvtInbox directory. When an NSE appears, the NS Receiver Service renames the NSE file and spawns a Router Object, which routes the NSE to a queue. This is usually used for stand alone inventory. 1b - The Altiris Agent passes the NSE via HTTP to the PostEvent.asp Web page. The NSE is passed through IIS, which spawns a Router Object. This Router Object routes the NSE to an event queue. This is how most NSEs get placed on the Notification Server. Inventory Solution for Windows Reference 46 Chapter 5: Troubleshooting 2 - The Router Object places the NSE into either the large event queue or the small event queue. The EvtQueue is the large event queue. This is primarily where inventory and other solution data is placed. The small event queue is primarily where status messages are placed. 3 - The NS Dispatcher Service monitors both event queues using two Dispatcher thread pools, one for the large event queue and one for the small event queue. NSEs get processed generally on a last in - first out basis. There is no order to which NSEs get processed. You cannot assume any order that the NSEs get processed. 4 - When an NSE appears in one of the event queues, the Dispatcher thread that is monitoring that queue moves the data into the Process directory. 5 - The NS Dispatcher Service, through a Dispatcher thread, gives the NSE in the Process directory to the Notification Server processes. 6 - The Notification Server processes create a process (Event Processor) that processes the event. This Event Processor finds which policy the NSE is attached to, looks at the Automated Actions that are in the policy, then acts on the NSE based on the policy and Automated Actions. This usually includes inserting the NSE data into the Notification Database. If the data is corrupted or cannot be processed, it is placed in a Bad event directory by the NS Dispatcher Service. Optional (can only happen if you have the Altiris Connector for SMS installed): 7 - If you have installed the Altiris Connector for SMS and the Notification Server is set up to forward data to SMS, MTS creates a process to pass the inventory data in native SMS format (MIF) to an SMS CAP (Client Access Point). 8 - The SMS Server picks up the inventory data from the SMS CAP. 9 - The SMS Server places the inventory data into the SMS database. DLL Requirements when using Windows 95 Stand-alone inventory uses DLL files that are placed on a computer when Internet Explorer 4.01 or later is installed. Computers running Windows 95 may not have enough disk space or memory to install and run Internet Explorer 4.01 or later. The following table shows the Internet Explorer DLL requirements needed to run stand-alone inventory on a Windows 95 computer. Agent Required DLL(s) Software Audit none required Custom Inventory updated AdvApi32.dll and OLE32.dll Machine Inventory setupapi.dll, cfgmgr32.dll, unicows.dll Exchange Inventory none required Inventory Collector unicows.dll Inventory Solution for Windows Reference 47 Agents This section provides information on the agents that you get when you install Inventory Solution. Quick Links “Software Audit Agent” on page 49 Performs an extensive audit of the programs and files that are on your computers. “Custom Inventory Agent” on page 69 Extracts values from the registry, INI files of the correct format, WMI queries, or file headers and reports these back as inventory data to Notification Server. “Exchange Agent” on page 82 Extracts mail profile information. “Serial Number Agent” on page 85 Reports detailed information about the serial number, computer model and manufacturer, memory modules, SMBIOS, and BIOS, providing a great way to track your business assets. “Machine Inventory Agent” on page 86 Collects software and hardware inventory. Inventory Solution for Windows Reference 48 Software Audit Agent The Software Audit agent discovers the applications and suites, such as Microsoft Office, on your computer without the hassle of maintaining a knowledge base. It also reports on used disk space of files such as MP3, DOC, AUI, etc. Whether working with one computer or thousands of computers, Software Audit agent provides you with an accurate picture of ALL the software installed on a computer. It's as if you searched Control Panel - Add/Remove Programs, the registry, the entire file system and carefully recorded the version number, path location, size, dates and the suite that the application is a part of and cataloged the information in one place for easy viewing. Audit provides much more than a raw dump of data - it provides much needed contextual information to help you really see what is important among the hundreds of files on your computer. For example, at a glance, you can see the browser or Office settings of a particular computer. For each file scanned, the following information is recorded (if available): Manufacturer, Product Name, Product Version, Language, File Name, File Size, Directory File Time, Executable Type, Internal Name, KnownAs, File Description, File Path, File Modification Time, and File Extension. Quick Links • “Software Audit Agent Overview” on page 49 • “Software Audit Agent Configuration” on page 54 • “Software Audit Agent Troubleshooting” on page 66 Software Audit Agent Overview • “Features and Benefits of the Software Audit Agent” on page 49 • “Input for the Software Audit Agent” on page 50 • “Customizing Audit Configuration” on page 50 • “audit.rul File Usage” on page 51 • “Files Needed to Run the Software Audit Agent” on page 51 • “Running the Software Audit Agent Using Logon Scripts” on page 51 • “How the Software Audit Agent Works” on page 52 Features and Benefits of the Software Audit Agent The Software Audit agent performs an extensive audit of the programs and files that are on your computers. This data can be viewed in real time or forwarded to a Notification Server. The Software Audit agent gathers product name, version, and language resource information out of the executable (EXE, DLL, OCX, and so forth) files that it finds on the disk. This is the same resource information that you can see by looking at the Version tab in the properties dialog of an executable file as seen in the Windows Explorer. Almost all Win32 executable files contain this resource information. Audit can generate the data in both MIF and XML formats. You can immediately view the XML formatted results of an Audit scan. This provides a real time support and diagnostic tool to track workstation software configuration issues. The XML data can also be loaded into the Notification Server database. The MIF data can be loaded to an SMS database. Inventory Solution for Windows Reference 49 Software Audit Agent Since the product name, version, and language resource information are part of the actual executable file, you can be sure that you are getting an accurate audit of what software is actually installed on your computers. For DOS and Windows 16-bit application files that do not contain resource information as part of the executable file, Audit looks up the name of the file in an audit.rul file to find an associated product name. Resource information that may be in Windows 16-bit applications is not used by the Software Audit agent. Only Windows 32-bit resource information is scanned by the Software Audit agent. The Software Audit agent can also notify you of any executable files that are on your computer that do not have resource information in them or an entry in the audit.rul file. Using this information, you can keep your audit.rul file up to date for legacy programs that are found in your environment. The full path, size, and executable type (DOS, Win16, Win32) of these unknown files are included in the output MIF. Easy to Customize The Software Audit agent comes with an easy to use configuration editor, found in install path\Altiris\Notification Server\NSCap\Bin\Win32\AeXAPedit.exe. This editor lets you easily customize how the Software Audit agent runs when scanning your computers. You can control settings such as which files are ignored in an audit scan, how to group sets of applications, and which drives and directories to include in the scan. (See “Modifying the Software Audit Agent Configuration File” on page 54.) Any file or product, such as the utilities included with the base operating system, can be excluded from the scan. This enables you to gather just the information you want from your computers and not receive a lot of unnecessary information about files and products that are either part of the operating system or products that you don't care to track. The Software Audit agent reports if an evaluation copy of the software or a licensed copy was run, the agent version, and the date the scan was run on a particular computer. This information is then visible as part of the inventory for that computer. Input for the Software Audit Agent The Software Audit agent receives input on how to run from the following sources: • Command line arguments control how the Software Audit agent will be run. • INI file that lists the scanning rules for local and remote computers. This file should be in the same directory as the auditpls.exe file. • audit.rul file is used to match files that do not have resource information in the file. This file should be in the same directory as the auditpls.exe file. You must copy your current version of this file to the agent directory. This is an optional file. Note: Inventory Solution does not provide a sample audit.rul file for you. If you are providing rules, you need to create this file. Command Line Arguments for AeXAuditpls For a listing of AeXAuditpls command line arguments, see “AeXAuditpls Executable” on page 95. Customizing Audit Configuration A sample INI file is included with the Software Audit agent: • auditpls.ini is the default INI file used by the Software Audit agent if no other INI file is specified on the command line. You can modify this INI file for use in your own network. You should use the Software Audit Agent Configuration Editor, AeXAPedit.exe, to edit the file. The Software Audit Agent Configuration Editor is an easy to use tool that lets you view and modify the various settings for the Software Audit agent. Inventory Solution for Windows Reference 50 Software Audit Agent audit.rul File Usage The audit.rul file is not required to run the Software Audit agent, but it will help in tracking the files that do not have any resource information in the executable that has been scanned (such as DOS applications). If there is resource information in the file, the audit.rul file is not used at all. The only information that is used out of the audit.rul file is the file name and optionally the file size. If there is a match of the file name and the file size, the associated package name for that file is used as the package name in the MIF that is created. No CRC or checksum validation is performed even if this information is stored in the audit.rul file. IMPORTANT: If you set the size to 0 or do not include a size, then the Software Audit agent informs you if it finds the file on the computer regardless of the size of the file. That is, it is a simple file name match. This can be very useful when you want to scan for data files that don't have resource data in them nor do they have a fixed size. Note: The way the Software Audit agent uses the audit.rul file is that if it finds ANY of the files that are listed in the section for the package, then that package will be reported. Also note that in parsing the audit.rul file, the name of the package must be surrounded in double quotes, and the names of the files and their sizes must each be on their own separate line. The following is a sample of an audit.rul file package 0 “Sample Product 5.0 English (International)” file “abc.exe” size 12345 file “xyz.exe” size 67890 package 1 “My private config file for xyx company” file “data1.dat” size 0 package 2 “Visual tests - automated” file “vistst.vis” IMPORTANT: The file lines under the package sections need to be indented at least one space relative to the package line. For example, the package lines should be on the left margin and the file lines indented at least one space from the left margin. If there is a file named abc.exe on the computer OR a file named xyz.exe and the file sizes match the settings in the audit.rul file, then the package will be reported in the output MIF file. Any CRC information stored in the audit.rul file is NOT used even if it is defined in the file. IMPORTANT: You must manually copy your audit.rul file into the directory from where the auditpls.exe file will be run. Files Needed to Run the Software Audit Agent When you run the Software Audit agent on target computers, there are two files that are needed along with one optional file: • AeXAuditpls.exe (see “Input for the Software Audit Agent” on page 50) • auditpls.ini (see “Customizing Audit Configuration” on page 50 and “Modifying the Software Audit Agent Configuration File” on page 54) • audit.rul (optional) (see “audit.rul File Usage” on page 51) Running the Software Audit Agent Using Logon Scripts Many Software Audit agent customers control the running of the Software Audit agent through a network logon script. The logon script references the auditpls.exe file and the Software Audit agent will run based upon the command line and auditpls.ini file parameters. For example, you can schedule the execution of the Software Audit agent so that it only runs every N number of hours. (See “Running AeXInvSoln.exe using a Logon Script” on page 21.) Inventory Solution for Windows Reference 51 Software Audit Agent How the Software Audit Agent Works This flow chart illustrates how the Software Audit agent performs its scans. Details of each step in the process are outlined below. Audit Agent 1. Begin Scan - Determine audit scan criteria 2. Start scan loop Yes 4. Disk usage counter Do next file 3. Data File? No 5. Read file resource data 6. Fill in KnownAs Data No 7. Pass general filters Yes 10. Write to special group 8. Special Group selection No 9. Write to standard group Yes 11. Also include in standard group No Yes 12. Done with file 1 Determine the command line arguments, and optionally the SMS version, to know where to place the XML and MIF files when they are produced. Inventory Solution for Windows Reference 52 Software Audit Agent 2 a Determine if the local computer should be scanned with the settings in the INI file. b Read from the designated INI file the list of remote drives to scan. c Determine the local hard drives attached to the computer. d Combine the drives from the previous two steps into a list. For each drive in the list, find all files with an extension that is contained in a list of extensions to scan. This list is obtained from the designated INI file. As the scan progresses, directories are tested against the excluded directories list for the local computer. All files in excluded directories are ignored. 3 Is this a data file who’s extension is found in Disk Usage of the Audit Configuration Editor (AeXAPedit)? 4 If yes, the file goes through the disk usage counter, then the Software Audit agent is done with the file. 5 For each qualifying file that matches one of the defined extensions, retrieve the following information: • File name and path • File date • File size • Product name (from resource) • Product version (from resource) • Manufacturer (from resource) • Language (from resource) • Internal Name (from resource) If there is no resource information in the retrieved file, the audit.rul file is examined for a matching file name and extension and file size. If a match is found, the product name from the audit.rul file is used. If no match is found in the audit.rul file, the file name (less the extension), uppercased, is used as the product name. The other resource information is left blank in the resulting output file(s) produced. 6 Fill in the Known As property for this record based upon any data set in the designated INI file. If no Known As mapping is defined, then the product name is placed in the Known As property. 7 For each qualifying file, compare the information retrieved in the preceding step against the exclusion list retrieved from the INI file. The following items may be present in the exclusion list: • Product Name (from resource) • Product Version (from resource) • Manufacturer (from resource) • Language (from resource) • File name (with extension) • File Date • File Size Any one or more of the items above may be specified in the exclusion list. If more than one item is specified, all specified items must match the equivalent items retrieved from the file for a file to be excluded. The strings that are present in the exclusion list can be regular expressions enabling the use of wildcard characters. These wildcard characters can be in the form “ABC*”, “*ABC”, and “*ABC*”. Inventory Solution for Windows Reference 53 Software Audit Agent Software Audit Agent Configuration If the retrieved file is not in the exclusion list, its Product Name and Product Version are compared against a list of Product Names and Versions already discovered during the current execution. If a match is found, the current file is added to the list of files associated with the Product/ Version. If no match is found, a new Product/Version entry is made. 8 Evaluate if the properties of the file designate that the data should be part of a special group. If so, write the data to the special group record in the output file(s). The data written to the output file(s) is constructed from the Product/Version list. XML files are posted in the target directory. MIF files are created in the local NOIDMIF directory on the target computer. Special group data is written to the output file(s). The name of the group and the group class are not the standard group, but rather the names as specified in the INI file. Data written to a special group is evaluated for inclusion in the standard group. The Software Audit agent finishes processing that file and then continues looking for additional files in the designated drives. If remote computers are to be scanned, a UNC connection is made to the share/volume and the files on the remote computer are scanned according to the same filtering logic described above. Software Audit Agent Configuration The Software Audit Agent Configuration Editor (AeXAPedit.exe) is a tool that helps you customize the Software Audit agent configuration files. With the editor, it is very easy to change and configure how the Software Audit agent runs. The Software Audit agent configuration files are used when the Software Audit agent scans a computer to produce the MIF files. The Software Audit Agent Configuration Editor is designed to be used by the administrator who is responsible for maintaining how the Software Audit agent is run. This tool is not visible to the end user when an Software Audit agent scan is run on the end user's computer. You do not ever need to make the Software Audit Agent Configuration Editor available to end users. IMPORTANT: It is recommended that the Software Audit Agent Configuration Editor (AeXAPedit.exe) and the Software Audit agent configuration file (*.ini) be in the same directory. If they cannot be in the same directory, these two files must be on the same computer. If they are on different computers, any changes to the Software Audit agent configuration file cannot be saved. Quick Links • “Modifying the Software Audit Agent Configuration File” on page 54 • “Scanning for a Single File or Files of a Given Extension” on page 55 • “Using the Software Audit Agent Configuration Editor” on page 56 Modifying the Software Audit Agent Configuration File To modify the Software Audit agent configuration file 1 Start the Audit Configuration Editor, install path\Altiris\Notification Server\NSCap\Bin\Win32\x86\AeXAPedit.exe. 2 Open the Software Audit agent configuration file (*.ini) that you want to modify. (A default configuration file named auditpls.ini is included with the Software Audit agent.) 3 Select the various tabs and change any information per your requirements. 4 Select File>Save to save the updated configuration file. 5 Run the Software Audit agent using the updated configuration file. Note that by default the Software Audit agent will use the auditpls.ini file in the same directory as auditpls.exe. Other INI file names can be specified for the Software Audit agent using the /INIFILE argument. Inventory Solution for Windows Reference 54 Software Audit Agent Software Audit Agent Configuration You might want to customize a configuration file for different files that you are scanning for. For example, you may want to have different file exclusion filters or change the name of the MIF groups where the data is reported. The default auditpls.ini file that is supplied with the Software Audit agent is simply a reference file for you to start from. Scanning for a Single File or Files of a Given Extension To scan for specific files or files with a specific extension 1 Open your auditpls.ini file with the Software Audit Agent Configuration Editor, AeXAPedit.exe. 2 In the File Masks tab of the editor, enter the proper file masks that you want to scan. This tells the Software Audit agent to process files of these file masks as part of the scan of the hard drive. 3 In the Exclusion Filters tab, you can specify files with certain extensions to exclude. 4 In the Special Groups tab, you can create a special group that includes just those files that you want reported. Click Add to create a special group. To edit a special group, click on the special group name, then click Properties. Using the configuration from the example below will place all comctl*.ocx, mcf*.dll, and vbrun*.dll files in a group called AeX SW MS DLLs. Inventory Solution for Windows Reference 55 Software Audit Agent Software Audit Agent Configuration The Advanced tab lets you select to scan in Package mode as opposed to File mode. File mode is the default unless you select Package mode. • Package Mode - Select this and click Yes to scan in Package mode. In Package mode, the scan will only report one instance of each file from a product package. A product package is defined by Product Name, Manufacturer, version (if selected), and language (if selected). If two scanned files have the same values for these properties, they are considered to be in the same product package and only the first file will be reported. • • • Use language in package compare package compare. - In Package mode, select Yes to use language in the Allow multiple versions per package - per package. In Package mode, select Yes to allow multiple versions File Mode - Clear the Package mode check box to select File mode. In File mode, each unique file will be reported. If there are multiple identical files, which are stored in multiple folders, only the first identical file will be reported. You can also select to Include files matching special group criteria in the standard group. Example: Suppose you have two files, one called “NSviewer.exe” and one called “NS.exe”, that both have Product Name = 'NS' and Manufacturer = 'Altiris'. In Package mode, if the scan views “NSviewer.exe” first, then only “NSviewer.exe” will be reported, and will represent the 'NS' package. In File mode, both “NSviewer.exe” and “NS.exe” are reported. Using the Software Audit Agent Configuration Editor Standard menu items are available on the File, Edit, and Help menus. When you have entered information in this editor, you must save your changes by clicking File > Save. The Software Audit Agent Configuration Editor interface has the following tabs: • “Advanced Tab” on page 57 • “Directories Tab” on page 58 Inventory Solution for Windows Reference 56 Software Audit Agent • “Disk Usage Tab” on page 59 • “Include Unknown Tab” on page 59 • “Exclusion Filters Tab” on page 59 • “File Masks Tab” on page 61 • “Known As Tab” on page 61 • “Manufacturer Known As Tab” on page 62 • “Overrides Tab” on page 62 • “Special Groups Tab” on page 63 Software Audit Agent Configuration Advanced Tab Under the Advanced tab you can make changes that override the default values used to generate data for MIF and XML files. Alternate MIF Directory - Indicates a user defined directory where the results of the scan should be placed. If this key is missing or blank, then the MIF file produced in the scan is placed in the NOIDMIF directory on the local target computer. Local MIF Name - This lets you name the MIF file that is created in the NOIDMIF directory on the local target computer. If no value is provided, then a file named audit*.mif is created in the NOIDMIF directory. Note that if you provide a file name, you need to also provide an extension of MIF so SMS will properly process the file. This feature is useful to be able to have the results of two different types of the Software Audit agent scans stored on the local computer. Note: The files are broken up into approximately 100 KB segments because SMS has a default limit for a single NOIDMIF. Slow mode delay (in milliseconds) - This indicates the number of milliseconds that the Software Audit agent will wait after scanning each file. Setting this value will cause the Software Audit agent to run much more slowly. However it will reduce the rate of disk I/O on the computer being scanned. If you run the Software Audit agent with a /hidden argument, this causes the scan to be much less noticeable on the end-user's workstation. Values from 5 to 20 are generally sufficient to make the scan much less noticeable. If the value is set in the hundreds, the scan can take many hours. The Software Audit agent has been built with a lower priority on the thread so that even if the hard drive is seeking a lot, regular applications being used by the user should still function quickly because the Software Audit agent will give them the processor. Override Default Settings for the Audit Group - Changing the Group Name and Group Class - Generally you don't need to change the defaults of the group names and the group classes. However, you can control the settings of how the data is reported to the database. If you want to maintain two separate snapshots on a computer, then you would need to modify the group names and group classes to keep the data from the two snapshots separate in the database. Report Groups - This specifies which groups of data to place in the output file(s). If Standard is selected, then only the products matching the standard group criteria will be reported. The standard group is AeX SW Audit Software. All other groups (except the disk usage, the audit, and disk usage summary) are special groups. If Special is selected, then only products matching the criteria for inclusion in one of the special groups will be placed in the output file. Both will generate entries for both groups. You might want to use the special group to be able to quickly limit the set of data that the Software Audit agent reports. For example, if you only wanted to know about files in Microsoft Office and Internet Explorer files, you could define the criteria for inclusion in those special groups and then only those files would be reported. Use Language in package compare - If this is set to Yes, then the value of the language attribute is used to determine a unique product. If it is set to No, the language is not tested when checking to see if a file belongs to a package. Manufacturer, Product Name, Product Version and Language are the attributes that can be used to determine a unique package. This argument tells the Software Audit agent whether to use Language or not. Inventory Solution for Windows Reference 57 Software Audit Agent Software Audit Agent Configuration Allow Multiple Versions Per Package - If this is set to Yes, files are checked for belonging to a package on the basis of 1) manufacturer, 2) product name, 3) product version, and 4) language. If this is set to No, files are checked on the basis of 1) manufacturer, 2) product name, and 3) language. (The product version is NOT used.) Selecting Yes means that if the Software Audit agent encounters 2 files, both with identical properties except for product version, then it will report both files. Product Exclusion Match - Indicates whether a product name that is used in an exclusion section needs to be an exact string match of the product name found in the scanned file or a partial match of a sub string. The default value is Substring. The possible values are Exact and Substring (case insensitive). Default Output Format - The Software Audit agent can generate output files in MIF and XML formats. Note that these settings can be overridden by the /output command line argument. XML Output Path - This lists the folder where the NSI file (contains the data in XML format) will be created. By default, the file will be created in the install path\Altiris\Inventory folder. Note that this setting can be overridden by the /o command line argument. Directories Tab Under the Directories tab you can specify which directories will or will not be included in the scan. For example, you may want to exclude the Program Files directory. The sub-directories under Program Files will also be excluded in the scan. The Software Audit agent includes all local drives by default. You can then choose to exclude one or more directories from the local drives from the scan. You can also choose to include remote directories (UNC or mapped) in the scan. Note: Subdirectories under the excluded or included directories are also excluded from or included in the scan, respectively. You can exclude directories with the exclusion option. Selecting only some directories to scan is difficult if not impossible, because you would have to exclude every other directory on the drive and you may not know what they are unless every computer in your environment is set up the same and stays the same. If one directory is different from what is explicitly defined in the exclusions list, you will not get the results you want. Do not use the exclusion option if you only want to know what is in certain directories. The option for including directories (Include this remote directory) is only for remote directories (directories which are not on the local computer). This option will only work well if all the computers using the same auditpls.ini file have the same mapped drive letters. Included directories are the first pass inclusion filter. Next, the excluded directories filter is applied when evaluating whether a directory should be scanned. The excluded directories is the list of directories to explicitly exclude from the set of directories that match the include criteria. For example, if you select Scan all local drives, you may still want to exclude C:\recycler and %temp% from the list of directories to be scanned. The listed directories are excluded from the scan as well as all subdirectories under the named directory. To specify a drive for inclusion or exclusion, simply designate <drive letter>:\ such as C:\. The Directories page supports wildcards. Note: Environment variables may be substituted to designate directories to exclude. The TEMP environment variable would be a typical environment variable to use. Environment variables are designated by being surrounded by the % symbol. Usage To include a remote directory, enter the directory location in the Include this remote directory field (or browse to the directory by clicking the Browse button), then click Add. To exclude a directory, enter the directory location in the Directory field (or browse to the directory by clicking the Browse button), then click Add. To remove a directory from either the include or exclude lists, select the directory, then click the button. Remove Inventory Solution for Windows Reference 58 Software Audit Agent Software Audit Agent Configuration Disk Usage Tab The Disk Usage page allows you to enter the file extensions you want to be included in a disk usage scan. For example, you may want to find out how much disk space is being consumed on target computers by digital audio files. You would enter extensions such as MP3, RM, WMA, and so on. Usage Enter the file extension in the Extension field and click Add. Or, select a file extension in the list and click Remove. Extension Include Unknown Tab The Include Unknown page lets you control the reporting of unknown files by type. Unknown files do not have a file header. If files have a file header, the Audit.rul file is not consulted. If unknown files do not have a file header but have an entry in the Audit.rul file, they will be included. It is only when files do not have a file header and do not have an entry in the Audit.rul file that this option needs to be selected so they can be included. Default unknown file information includes: • Product Name (from Description) • File Name • File Size • Directory File Time • Executable Type • Known As • File Path • File Modification Time • File Extension You can define whether you want to be notified of these files on a per executable file type basis. Thus if you want to know of unmatched files that are Win32 executables but not unmatched DOS executables, you control it through these checkboxes. Include Unknown also effects the XML output. To use this option, an Audit.rul file must be included in the same directory as the Software Audit agent is running from. However, the Overrides option in the Configuration Editor is preferable to using the Audit.rul file. The Overrides option is more powerful than using the Audit.rul file. Exclusion Filters Tab The Exclusion Filters page enables you to specify criteria to exclude files from the scan. This allows you to exclude files you do not care about. Any file that meets the filter criteria will not be evaluated for inclusion in the results XML file or for inclusion in the MIF file. Note to users of Application Management Solution: You can copy and paste entries from a File Snapshot Editor rule into the Exclusion Filters Rules. This makes it very simple to add to your exclusion filters. If you don't want to track given files for audit analysis, add this into the exclusion filters. You can add filters, delete filters, or change the properties of existing filters. Select the appropriate button on the page for the associated action on the selected filter. You can sort on any column by clicking on the column header. Columns can be resized by selecting the column divider and moving the mouse left or right. Column order can be changed by clicking a column header and then dragging to the new location. Inventory Solution for Windows Reference 59 Software Audit Agent Software Audit Agent Configuration Filters can be copied and pasted into the clipboard. Filters are available in the clipboard in a tab delimited format. Using this, you can easily export the data to a spreadsheet or other reporting tool. When the text <any> appears in a cell, it indicates that this file property will not be used when the Baseline program is evaluating exclusion filters. The Filter Properties dialog lets you specify whether a given file property will be used as a filter criteria. Each exclusion filter must contain at least one of the values described below. If more than one value is specified, the values for all keys specified must be matched for a product to be excluded. Exclusion criteria are ADDED together when comparing with a particular file. The exclusion criteria are Filename - Specifies a string to be compared with the retrieved file name. The comparison is a caseinsensitive comparison of the entire string, excluding trailing white space. Product Name - Specifies a string to be compared with the product name retrieved from the resource table. The comparison is a case-insensitive comparison of the entire string, excluding trailing white space. So a string of “operating system” will exclude any file with the words operating system in the product name. Product Version - Specifies a string to be compared with the product version retrieved from the resource table. The comparison is a case-insensitive comparison of the entire string, excluding trailing white space. Manufacturer - Specifies a string to be compared with the manufacturer string retrieved from the resource table. The comparison is a case-insensitive comparison of the entire string, excluding trailing white space. Language - Specifies a string to be compared with the language string retrieved from the resource table. The comparison is a case-insensitive comparison of the entire string, excluding trailing white space. FileSize - Specifies a file size in bytes to be compared with the retrieved file size. This is an exact numeric comparison. All of the fields of the Exclusion Filters page support wildcards. To add an exclusion filter 1 Click the Add button. 2 In the General tab, if you want to retrieve information from a specific file, click the Get Resource Information From File button, navigate to a file, then click Open. 3 To match to a file name, select Filename match required, then enter the file name in the Filename field. 4 To match to a directory name, select Directory match required, then enter the directory name in the Directory field. Note: This is only available if you have selected Filename match required. 5 To match to a product name, select Product name required, then enter the product name in the Product name field. 6 To match to a product version, select Product version required, then enter the product version in the Product version field. 7 To match to a manufacturer, select Manufacturer required, then enter the manufacturer in the Manufacturer field. Select Only qualify if Manufacturer blank or missing Manufacturer field is blank or missing. if you want the filter to work only if the 8 In the Advanced tab, to match to a language, select Language match required, then enter the language in the Language field. 9 To match to a file size, select File size required, then enter the file size in the File size field. 10 Click OK to save the changes. Inventory Solution for Windows Reference 60 Software Audit Agent Software Audit Agent Configuration To edit an exclusion filter 1 Select the exclusion filter you want to edit. 2 Click the Properties button. 3 Make the changes you want, then click OK. To delete an exclusion filter 1 Select the exclusion filter you want to delete. 2 Click the Delete button. 3 Click OK. File Masks Tab The File Masks page is where you specify which file masks are included in the Software Audit agent scan. Note: This tab used to be known as the Extensions tab. It only allowed you to enter extensions. Now you can enter file masks as well as extensions, providing you much more flexibility. IMPORTANT: If you include data file masks, you must also select on the Include Unknown tab the option for 'invalid' files. Data files do not have header/resource information and they are considered 'invalid' files because the Software Audit agent uses header information. You can also use the Overrides section to give data files some header information and then this option would not be necessary. For example, for the value *.doc, you could give the files a product name, manufacturer, language, and version and then they would be included automatically without having the Include Unknown option selected. Of course, if you do this, all *.doc files will have the same product name, manufacturer, language, and version information. They would just have different file names and paths. File masks are in the form of: *.exe test*.xl? Note: If there is not a “.” in the name, “*.” is automatically prepended so old style entries (exe, doc) will still work. This way, your old INI's will not be broken. You can include data file extensions as well. If you want to scan for files without an extension, you can enter: *. Usage 1 Enter a file mask in the File Mask field. 2 Click the Add button. 3 The file masks that you want reported are displayed in the File Masks list. 4 To delete a file mask from the list, select a file mask in the File Masks list, then click Remove. Known As Tab The settings under this tab allow you to define a name based on a product’s Internal Name which is read from the version resource data. For example, the internal name for the game Minesweeper is winmine, but the game itself is known as Minesweeper. This is useful for reporting purposes. For example, you may want to track all of the components of Microsoft Office or various components of the operating system such as Internet Explorer. Inventory Solution for Windows Reference 61 Software Audit Agent Software Audit Agent Configuration When the Software Audit agent finds a file and scans the resource data, the Known As attribute is always initially set to the Product Name. The Known As value is changed in the following situation: If the Software Audit agent is being run with an INI file which has Known As mappings defined, and if the Internal Name of the file is defined in this list, then the Known As attribute will be changed to the value of that key. The Known As attribute is reported in the MIF for easier tracking purposes. The fields in the Known As page support wildcards. Usage Enter the Internal Name and the Known As name and click Add. To find the Internal Name of a program, right-click the program file and select Properties from the menu. In the Properties dialog box, click the Version tab. Under the Other version information heading, click Internal Name. Example Assume that you want to know if duplicate copies of MFC runtime DLLs are on your computer. You can use the Internal Name of MFC40.DLL, MFC.DLL, and provide a Knows As name of MFC Runtime DLL. This way, reports that utilize this information will have a better context about the nature of the file. If you do not supply a Known As mapping, then the product name will be substituted for the Known As field. Manufacturer Known As Tab The Manufacturer Known As page lists the mappings of manufacturer names to a common manufacturer name. A number of manufacturers do not consistently use the same characters in the manufacturer field of their applications. Each entry lets you specify a string, which is automatically converted to a regular expression. Then, any time the Software Audit agent encounters a file that matches the regular expression, it will replace it with the Manufacturer Known As value. The benefit of this is that, as the data is loaded into the Notification Server, a consistent string for the manufacturer is used. For example, suppose you have files with the following values for manufacturer: • Microsoft Corp. • Microsoft(r) Corporation • Microsoft Corporation Enter “Microsoft” in the Manufacturer name field and “Microsoft Corporation” in the Replace with field, then click Add. All the variants of Microsoft will then be reported under the same Manufacturer name. You can also enter a regular expression in the Regular Expression field. To remove an alias, click on the alias, then click Remove. The fields in the Manufacturer Known As page support wildcards. Overrides Tab Under the Overrides tab, you can override the properties of a file in order to clean up the information before it is reported into your database. For example, suppose in looking at report data you note that various data would be more useful if it was presented slightly differently. With the overrides, you can define exactly how data will be reported back to the database regardless of the version resource data that is already present in the file. All of the fields of the Overrides page support wildcards. This can be useful as you work with files that might have similar names, such as different versions of the same product. Items in the Overrides tab are applied first before any other processing. The Overrides look to all of the other rules in the Software Audit agent as though the information was retrieved from the file header/resource information in the way the Overrides set it. If there are rules in the Known as field Inventory Solution for Windows Reference 62 Software Audit Agent Software Audit Agent Configuration on the Known As page which map the internal name (as set in the Overrides) to something else (even if the Overrides had set the Known as to something else) the Known as field on the Known As page is given preference. See “Known As Tab” on page 61. To add override properties 1 Click the Add button. 2 Specify the match criteria and the override values for a file. a In the A file with this property column, enter the information about the file. A blank value in this column designates “any” value. If you want to retrieve information from a specific file, click the Get Resource Information From File button, navigate to the file, then click Open. b In the is to be overridden with this property column, enter the overriding information. A blank value in this column carries over the value from the A file with this property column. 3 Select Use file size, and then enter a file size if there is a file with a specific file size whose information you want to override. 4 Select Use directory time, and then enter a time if the file whose information you want to override is in a directory with this time stamp. 5 Select Use file modification time, and then enter a time if the file whose information you want to override has this time stamp. 6 Click OK to save the changes. To edit override properties 1 Select an overrides from the list. 2 Click the Properties button. 3 Edit the fields as needed. 4 Click OK to save the changes. To delete override properties 1 Select an overrides from the list. 2 Click the Delete button. Special Groups Tab The Special Groups page lets you identify a group of files you want to be tracked together. When you specify the group name and the group class, a new table is created in the Notification Server database with the group’s applications. This improves the reporting options on those applications. For example, you may want to create special groups to track items such as Microsoft Office components, Operating System components, games, standard desktop applications, or any other logical grouping of data that you may want in your environment. To be useful, the special group must also provide some selection filter information. This consists of a prescription of logical operations to be performed on attributes, and the list of attribute key/value pairs to match to. The six attributes used are: • Filename • Internal Name • Known As • Manufacturer • Product Name • Product Version Inventory Solution for Windows Reference 63 Software Audit Agent Software Audit Agent Configuration The columns that are generated in special groups are the same columns that are generated in the standard group. However, since the group name is different, the data is loaded into a different table in the database. This lets you organize your software audit data according to how you want to view the information. Each special group has its own group name and group class. You must fill in these parameters. Then you must also define the criteria of which files of which properties meet the criteria for inclusion into these special groups. Logical operations may be AND or OR and are prescribed in the following way: Manufacturer logical op = AND Product Name logical op = AND Product Version logical op = AND Etc. The default for logical operations is OR. If there is only one attribute with an AND, it becomes an OR. For example, [SpecialGroup.5] GroupName= SpecialGroup5 ClassName=SpecialGroupClass5 Manufacturer Logical Op = AND Manufacturer = Microsoft Corporation Manufacturer= Altiris would cause any file with a manufacturer of Microsoft Corporation or Altiris to be matched. IMPORTANT: Logical operations always apply between different attributes; they apply between Filename, Manufacturer, Product Name, Product Version, Internal Name, KnownAs. They never apply between different instances of a given attribute, such as between Manufacturer = Microsoft Corporation, and Manufacturer = Altiris. The logic operator used between different instances of a given attribute is ALWAYS an OR. In addition to the logical operators, a list of attributes should be given in the form of key/value pairs. Any attribute may occur any number of times. For example: Manufacturer = Microsoft Corporation Manufacturer= Altiris Manufacturer= Borland Manufacturer= Apple Computer Manufacturer= Cyberware Manufacturer= Lotus Manufacturer= Novell If a file contains ANY of the above manufacturer values, it is matched for the manufacturer attribute. In general, each attribute has a vector of values. If a file matches any of the values in that vector, then that attribute is matched. After an attribute vector is matched for a specific file, the other attribute vectors are tested. Then the logical operations are performed between attributes. This is done for each file, for each special group. When a group match occurs, the file information is buffered for that special group. Allow files matching special group criteria in the standard group is a global setting that lets you specify whether files/products that are part of a special group should also be evaluated for inclusion in the standard group. If this setting is cleared, files which match a special group definition will only be reported in that special group even if they match the overall settings for the standard group (AeX SW Audit Software). If this setting is selected, then files which match a special group definition will also be matched against the standard group definition and they will be included in the standard group if they meet the criteria. For SMS clients, the data is placed in the NOIDMIF directory on the client. Inventory Solution for Windows Reference 64 Software Audit Agent Software Audit Agent Configuration To add a Special Group 1 Click the Add button. 2 In the New Special Group dialog box, in the General tab, type the name of your group in the Name field. 3 In the Class field, enter the class grouping. 4 Enter a GUID (Globally Unique Identifier) for this Special Group. Generate a new GUID using a utility like guidgen.exe and copy the same GUID for the GUID value. 5 Select an attribute from the Attribute drop-down list. 6 In the Value field, enter a value or browse to find the value you want. Note: You cannot browse if you have selected Known As in the Attribute drop-down list. For example, if you have selected Filename in the Attribute drop-down list, browse to a file that you want included in the group, select it, then click Open. 7 Repeat the previous step until all desired values are listed under Attribute Values. 8 Click the Advanced tab. This tab lets you select to scan in Package mode as opposed to File mode. 9 If you want to use Package mode, select the Package mode check box, then click the Yes radio button. Clear the Package mode check box to select File mode. 10 11 If you want to use language in the package compare, click the Yes radio button under Use language in package compare. If you want to allow multiple versions per package, click the Yes radio button under Allow multiple versions per package. 12 Select Include files matching group criteria in the standard group if desired. This places the files in the standard group whether or not they pass the exclusion filter parameters. 13 Click OK to close the New Special Group dialog box. To create a data class for a new Special Group 1 Add a new Special Group as explained in To add a Special Group. 2 Locate the SpecialGroup.config file in install path\Altiris\Inventory\Config. 3 Copy this SpecialGroup.config file and paste it with a different name (for example: New_SW_Group_Name.Config or SW Visio.config). 4 Edit the New_SW_Group_Name.Config file using an editor such as Notepad.exe. 5 Replace the text “XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX” with the newly generated GUID that was generated in Step 4 in To add a Special Group. 6 Replace all the occurrences of the text “NEW SW SPECIAL GROUP NAME” with the new SW Special Group name that you want to create. Examples are provided in the SpecialGroups.config file. 7 Save this config file. 8 Edit the InventorySolution.config file that is located in the install path\Inventory Solution\Config folder a In the ProductInstallation section, locate the following comment: <!-- Add the reference of SpecialGroup.config file that you created e.g. <items source=”New_SW_Group_Name.config”></items> --> b After this comment, add the following line: <items source=”New_SW_Group_Name.config”></items> Note: Replace New_SW_Group_Name.config with the name that you gave to the new file you created. c Save the InventorySolution.config file. Inventory Solution for Windows Reference 65 Software Audit Agent 9 Software Audit Agent Troubleshooting Run AexConfig.exe from a command prompt and configure InventorySolution.config. This creates the new dataclass in Normalized form (see “Normalization” in Inventory Solution Help). To edit the properties of a Special Group 1 Select a Special Group. 2 Click the Properties button. 3 Make the changes to the group that you want. 4 Click OK. To delete a Special Group 1 Select a Special Group. 2 Click the Delete button. Software Audit Agent Troubleshooting Run auditpls /? for help on the available command line arguments. The output data is a MIF file in the NOIDMIFs directory and an NSI file in the install path\Altiris\Inventory folder. Quick Links • “How to Scan For Data (XLS, DOC, PPT, QWB, etc.) Files” on page 66 • “How to Use the Software Audit Agent Through a Logon Script for Windows 95/98” on page 66 • “How to Find Just One File With the Software Audit Agent” on page 67 • “How to Handle Win32 Files when the Software Audit Agent does not Currently Read the Version Resource Information” on page 68 How to Scan For Data (XLS, DOC, PPT, QWB, etc.) Files To scan for data files you must have the Invalid argument set to No as in the following example. [Exclude Audit.rul Unknowns] Exclude DOS=Yes Exclude WIN16=Yes Exclude VXD=Yes Exclude OS/2=Yes Exclude WIN32=Yes Exclude INVALID=No The reason for this is that the Software Audit agent tests the file to determine what type it is (DOS, WIN16, etc.) and data files do not return a match for any of the classifications that the Software Audit agent uses, so the Software Audit agent classifies them as invalid. So if the exclude section for invalid is set to yes, these files will be excluded even if their extension (XLS, PPT, DOC, etc.) is included in the extensions to be scanned. Note: You can view the overall count information by using the Disk Usage page. How to Use the Software Audit Agent Through a Logon Script for Windows 95/98 Create a script to copy down to the clients the auditpls.exe and INI files. Copy them into a directory which is sure to be in the path, like the windows directory. Then the Software Audit agent can be called from a start command in the logon script. Since auditpls.exe will be running locally on the computer there will be no pagefault errors by auditpls.exe when the logon script finishes processing, exits, and takes down the connection to the server established during the logon process. Inventory Solution for Windows Reference 66 Software Audit Agent Software Audit Agent Troubleshooting The reason this is necessary is that Win95/98 removes the connection (during the logon process Win95/98 makes a connection to the Netlogon share which it maps as the Z: drive) that any program uses if it is being run from the Netlogon share. Using the start command in a logon script to call a program lets the logon script finish processing, exit, and lets the user start using the desktop, when run on Windows NT. In Windows 95/98 programs called with the start command depend on the Z: drive mapping for their connection and Win95/98 will remove this connection as soon as it is done processing. So either the Software Audit agent needs to be called without using the start command (which means the logon script will pause until the Software Audit agent is done processing) or copy the Software Audit agent files to the client and call them with the start command. How to Find Just One File With the Software Audit Agent To find one or a few files, you will need to modify the auditpls.ini file. You can use the following sections which are the crucial sections to make this work: • This is the exclusion section which will exclude all files. [exclusion.2] manufacturer=a [exclusion.2] product name=a [exclusion.2] manufacturer=e [exclusion.2] product name=e [exclusion.2] manufacturer=i [exclusion.2] product name=i [exclusion.2] manufacturer=o [exclusion.2] product name=o [exclusion.2] manufacturer=u [exclusion.2] product name=u [exclusion.2] manufacturer= [exclusion.2] product name= • This is the section that will find just the one file you want. # This is where you put in the information on which file you want to file. # You can look for the file by any single attribute or combination according to the rules for special groups [Special Group.1] Group Name=Audit Software classname=ALTIRIS|AUDIT_SOFTWARE|1.0 internal name = invPLSNT (Note: Add any additional inclusion properties here for other files to find.) • This section of the INI file might need some modifications: # If the file you are looking for is not a Win32 file you will need to change some of these exclude lines [Exclude Audit.rul Unknowns] Exclude DOS=YES Exclude WIN16=YES Exclude VXD=YES Exclude OS/2=YES Exclude WIN32=yes Exclude INVALID=YES Note: Typically the best way to find a file is by the internal name. Inventory Solution for Windows Reference 67 Software Audit Agent Software Audit Agent Troubleshooting How to Handle Win32 Files when the Software Audit Agent does not Currently Read the Version Resource Information The Software Audit agent can inventory Windows 32-bit files where the version resource information does not fit the standard that the Software Audit agent was built to handle. In the Software Audit Agent Configuration Editor, put a check mark in the WIN32 checkbox in your existing auditpls.ini file. The Software Audit agent will be able to find the file and report the file name, size, date, type of file, and the product and internal name fields will be populated with the file name (minus the dot and extension - .dll, .exe, etc.). Inventory Solution for Windows Reference 68 Custom Inventory Agent Software Audit Agent Troubleshooting Custom Inventory Agent Inventory Solution provides a utility that extracts values from the registry, INI files of the correct format, WMI queries, or file headers and reports these back as inventory data to Notification Server. This utility is called Custom Inventory (AeXCustInv.exe). It can be run from within the inventory agent INI file. Note: For advanced users, professional services are available through Altiris. Contact your Altiris representative for more information. Custom Inventory is a utility that will read a given input file, perform appropriate text substitutions, and write a resulting output file. The substitutions are based on a simple syntax including some basic control structures, output directives and expressions allowing the retrieving of values from sources such as the registry, INI files, WMI, and file header information. In Inventory Solution, this will typically be used to generate Notification Server Inventory (NSI) format files. However the first principle of the Custom Inventory agent is that it is completely unassuming about the format of the template and works in a pure text processing manner. The Custom Inventory agent is useful because it lets you collect customized data. A file named AeXCustInv.xml is provided as a template and is in the same directory where AeXCustInv.exe is found. You must customize this file before running the Custom Inventory agent. Custom Inventory uses the information found in AeXCustInv.xml to create a file called AeXCustInv.nsi. It then places AeXCustInv.nsi in the inventory output folder (the default is install path\Altiris\express\Inventory). Quick Link • “Custom Inventory Agent Administration” on page 69 Custom Inventory Agent Administration Custom Inventory reads scripts that indicate what item settings to scan. In order for Custom Inventory to work, Internet Explorer 4.01 or higher must be present on the computer. The sample script AeXCustInv.xml is included with the Inventory Solution files. AeXCustInv.xml must be present in the same directory where AeXCustInv.exe resides. You can edit AeXCustInv.xml by adding or removing sections to customize the set of data reported in the output NSI file. Simply use the existing AeXCustInv.xml as the basis for the syntax. When you edit this file, make sure that for each new group that you create, you use a custom name. AeXCustInv.xml is a template file and is not valid XML. It contains placeholders that require valid XML substitutions. The Custom Inventory agent reads AeXCustInv.xml, replaces the placeholders, then creates a valid NSI file, AeXCustInv.nsi. The file AeXCustInv.nsi is then placed in the inventory output folder (the default is install path\Altiris\Inventory). • “Custom Inventory Agent Command Line Arguments” on page 69 • “XML File Syntax and Examples” on page 70 Custom Inventory Agent Command Line Arguments For a listing of Custom Inventory agent command line arguments, see “AeXCustInv Executable” on page 96. Inventory Solution for Windows Reference 69 Custom Inventory Agent Software Audit Agent Troubleshooting XML File Syntax and Examples The Custom Inventory agent uses text substitution according to certain placeholders. These are marked using the delimiters <% and %> and commencing with a keyword such as in <%set … %>. All recognized placeholders are evaluated in turn and the placeholders are either removed or replaced with a result according to the statement. If a placeholder for any statement other than write or writexml is followed only by white space, then up to and including the end of line is removed. The line or lines the placeholder is on will be removed if nothing else is on that line or lines. Placeholders, in particular the foreach, can span multiple lines. Nesting any of the following statements and control structures are allowed. For example, you can set up a loop of registry sub-keys and use the values retrieved to then base another loop (possibly consisting of other registry keys and values) or use in a nested WMI loop. You can also use conditionals (i.e. if) within loops, based on loop variable expressions. Following is a listing of the syntax used to extract data, as well as a number of example classes that demonstrate the use of this syntax. To use these examples, copy the desired text into a Notepad text file of its own and name this file AeXCustInv.xml. Place this file in the same directory as the AeXCustInv.exe file and run this executable. The output will be placed in the inventory output folder (the default is install path\Altiris\express\Inventory). Alternatively, a command line can be used to select the input/output file name and location. Note: The writexml tag takes the output and runs it through a filter to make sure it is XML compliant. It only gets output if it is XML compliant. Standard Expressions <%set varname= “expression” %> <%write “expression” %> Example <%set var1 = “My Value”%> <%write “example text”%> Note: Binary data is written out as a string. The length of the string is limited to 255 chars, which represents 85 bytes of binary data. Example c4= “<%write “reg:HKEY_LOCAL_MACHINE\SOFTWARE\MICROSOFT\DirectX\InstalledVersion”%>” If InstalledVersion is the binary number 00 00 00 07 00 00 00 00, then c4 in the NSI file would be the following string: c4= “00 00 00 07 00 00 00 00” <%writexml “expression” %> Example c4= “<%writexml “reg:HKEY_LOCAL_MACHINE\SOFTWARE\MICROSOFT\DirectX\InstalledVersion”%>” This causes an EscapeXmlText to be done. “reg:path” Example <%set variable= “reg:HKLM\Software\Altiris\AeXNS\Version” %> This lets you look up a registry value. “ini:path\[section]\name” Example <%set path= “c:\altiris\AClient\AClient.ini” %> <%write “ini:%path%\[section34]\group” %> This lets you look up an INI file value. Inventory Solution for Windows Reference 70 Custom Inventory Agent Software Audit Agent Troubleshooting Standard Expressions “file:%filepath%|FileProperty” This lets you retrieve file header information. The following values can be used for FileProperty. They all represent fields within a file’s version header block. • FILENAME - name of the file without the path portion • FILE_VERSION • PRODUCT_NAME • PRODUCT_VERSION • MANUFACTURER • LANGUAGE • INTERNAL_NAME • FILESIZE - not contained in the version header block • PATH - the full path of the file without the filename (this is not contained in the version header block) • MODIFIED_DATE • ORIGINAL_DATE • DESCRIPTION • COPYRIGHT The following property can be used for FileProperty and will return “Yes” or “No” based on whether the file is a Windows computer protected file: • IS_SYSTEM_PROTECTED - Win2K/XP/ME Only, otherwise returns “No” The following properties can be used for FileProperty and are obtained from the Win32 API “GetFileAttributes” for the file: • IS_ATTR_ARCHIVE • IS_ATTR_COMPRESSED • IS_ATTR_DEVICE • IS_ATTR_DIRECTORY • IS_ATTR_ENCRYPTED • IS_ATTR_HIDDEN • IS_ATTR_NORMAL • IS_ATTR_OFFLINE • IS_ATTR_READONLY • IS_ATTR_NOT_CONTENT_INDEXED • IS_ATTR_REPARSE_POINT • IS_ATTR_SPARSE_FILE • IS_ATTR_SYSTEM • IS_ATTR_TEMPORARY Examples <%set var1=“file:%filepath%\wmplayer.exe|PRODUCT_VERSION”%> <%writexml “file:%filepath%\wmplayer.exe|PRODUCT_NAME”%> <%writexml “file:%FILELOCATION%|IS_ATTR_HIDDEN”%> You may specify any environment variable within any part of your input file and it will be resolved prior to any processing. Example <%set file= “%path%\AClient.ini” %> Inventory Solution for Windows Reference 71 Custom Inventory Agent Software Audit Agent Troubleshooting Statements Conditional <%if <expression> %> <statement> <%endif%> <expression> = simple expressions: x = 'y', x like ?y, x > y, x < y, x <> y, x!=y If the expression evaluates to true, then all the text between the if and endif lines are included, with standard AeXCustInv processing performed upon them. Otherwise, the lines are omitted. The expressions supported are simple binary expressions using operators (=, <>, <, >, like). Variables may be used on either side of the operator. The like operator allows matching against regular expressions. Complex expressions involving the testing of values read from such as the registry may be achieved by first setting the value into a variable. Examples <%if %var1 = “My Value”%> <%set ver= “reg:HKLM\Software\Altiris\eXpress”%> <%if %ver% = “5.0”%> <%set enabled= “wmi:obj.Enabled”%> <%if %enabled% = “true”%> <%set path= “HKLM\Software\Altiris\eXpress”%> <%set nsver= “%path%\Notification Server\Version”%> <%set nscver= “%path%\Altiris Agent\Version”%> <%if %nsver% = “%nscver%”%> WMI For Each <%foreach wmiobject= “o” namespace= “namespace” wql= “select ...” %> c0= “wmi:o.propertyname1” c1= “wmi:o.propertyname2” <%next%> Registry For Each <%foreach regkey= “k” path= “HKLM\Software…” %> c0= “key: k.propertyname1” c1= “key: k.propertyname2” <%next%> Setting a variable <%set varname= “expression” %> This results in the variable being available for use in subsequent AeXCustInv expressions using the syntax %varname% (see example below). The entire placeholder is replaced with an empty string (i.e. it is not written to the output). Examples <%set var1 = “My Value”%> Writing out an evaluated expression <%write “expression” %> The entire placeholder is replaced with the resulting evaluation of the expression, not including the quotes. <%writexml “expression” %> Same as with write above, with the result being replaced as appropriate for use as an XML attribute or element value. Examples <%write “hello world”%> <%write “My Value is %var1%!”%> <MyNode text= “<%writexml “My Value is %var1%!”%>”/> Inventory Solution for Windows Reference 72 Custom Inventory Agent Software Audit Agent Troubleshooting Statements Iteration of registry keys <%foreach regkey= “k” path= “reg path expression” %> arbitrary text - typically includes some write statements using a key: expression. <%next%> The reg path expression can contain variables. The key: expression allows referencing the key variable to access a value of the key and is illustrated in the example below. Keyname You can access the registry key name itself by specifying the reserved word: “%keyname%” Default value for a key You can access the default value for a registry key by specifying the reserved word: “%default%” Example <%foreach regkey= “k” path= “HKLM\Software\Altiris\eXpress\Notification Server“ %> Version= “<%write “key:k.Version”%>” Path= “<%write “key:k.Path”%>” Key= “<%write “key:k.%keyname%”%>” DefValue= “<%write “key:k.%default%”%>” <%next%> Iteration of WMI object collection <%foreach wmiobject= “o” namespace= “namespace” wql= “select ...” user= “UserID” pw= “PW” %> arbitrary text - typically includes some write statements using a wmi: expression <%next%> Note: UserID and PW are optional. The namespace and wql values can contain variables. The wmi: expression allows referencing the WMI object to access a property of the object and is illustrated in the example below. Example <%foreach wmiobject=“o” namespace=“ROOT\CIMV2” wql=“select * from __EventFilter” user=“MYDOMAIN\jennifer” pw=“myPW” %> Start object Name=“<%write “wmi:o.Name”%>” Class=“<%write “wmi:o.__Class”%>” End object <%next%><%next%> Writing a section of the input file to a separate file Use the <%Startfile%> <%endfile%> block to designate that the text outlined by that block should be written to a separate output file. Keyword Reference Foreach (wmi) <%foreach wmiobject=“arbitraryID” namespace=“WBEM namespace” wql=“WMI Query”%> user=“UserID” pw=“PW” (Note: UserID and PW are optional) . <%next%> Foreach (Reg) <%foreach regkey=“arbitraryID” throttle=“%THROTTLEEVERY%,%SLEEPMS%” path=“registry path” maxIO=“100000000000000”%> . <%next%> Inventory Solution for Windows Reference 73 Custom Inventory Agent Software Audit Agent Troubleshooting Keyword Reference If <%if Conditional Statement %> . <%endif%> Set <%Set “Statement”%> Write <%Write “Statement”%> Writexml <%Writexml “Statement”%> Startfile (with specific filename) <%startfile name=“filename”%> . <%endfile%> Startfile (with specific tempfile extension) <%startfile tempfileext= “temp filename extension”%> . <%endfile%> Inventory Solution for Windows Reference 74 Custom Inventory Agent Software Audit Agent Troubleshooting Variables AeXCustInv.exe supports several variables for use by input scripts. The following demonstrates these variables and how they can be used within XML input to control the NSI output. For WMI and IE detection, if the variables have a value, then the component was found. Otherwise, the variable value will be empty. Note: These variable require AeXCustinv version 1.0.0.18 or greater. The variable names are: OS_NAME: The operating system in use. Possible values are: • “DOS” • “Windows3” • “WindowsCE” • “9X” • “NT” • “W2K” • “XP” OS_MAJOR: The ‘major’ version of the OS. OS_MINOR: The ‘minor’ version of the OS. OS_BUILD: The build number of the OS. OS_SP: The service pack level of the OS. WMI_MAJOR: The ‘major’ version of WMI found on the computer (empty if WMI not found). WMI_MINOR: The ‘minor’ version of WMI found on the computer (empty if WMI not found). IE_MAJOR: The ‘major’ version of Internet Explorer found on the computer (empty if IE not found). IE_MINOR: The ‘minor’ version of Internet Explorer found on the computer (empty if IE not found). Below is a sample script showing how these values can be used: Os Information: %OS_NAME% %OS_MAJOR%.%OS_MINOR% build:%OS_BUILD% Service Pack:%OS_SP% OS_VARNAME = %OS_NAME% OS_MAJOR_VARNAME = %OS_MAJOR% OS_MINOR_VARNAME = %OS_MINOR% OS_BUILD_VARNAME = %OS_BUILD% OS_SP_VARNAME= %OS_SP% <%if %WMI_MAJOR% != “”%> WMI Found on machine. Version: %WMI_MAJOR%.%WMI_MINOR% WMI_MAJOR = %WMI_MAJOR% WMI_MINOR = %WMI_MINOR% <%endif%> <%if %IE_MAJOR% != “”%> IE Found on machine. Version: %IE_MAJOR%.%IE_MINOR% IE_MAJOR = %IE_MAJOR% IE_MINOR = %IE_MINOR% <%endif%> The following are some examples that produce valid NSI output files. Example 1: WMI Query <?xml version=“1.0” encoding=“windows-1252”?> <InventoryClasses> <InventoryClass name=“CustInv Sample” manufacturer='CompanyABC' description=’ ’ platform='Win32' version='1.0' mifClass='COMPANYABC|CUSTINVSAMPLE|1.0'> <xml xmlns:s=“uuid:BDC6E3F0-6DA3-11d1-A2A3-00AA00C14882” xmlns:dt=“uuid:C2F41010-65B3-11d1-A29F-00AA00C14882” xmlns:rs=“urn:schemas-microsoft-com:rowset” xmlns:z=“#RowsetSchema”> <s:Schema id=“RowsetSchema”> <s:ElementType name=“row” content=“eltOnly” rs:updatable=“true”> <s:AttributeType name=“c0” rs:name=“Event Filter Name” rs:number=“1” rs:basecolumn=“Event Filter Name” rs:keycolumn=“true” mifAttrId=“1”> <s:datatype dt:type=“string” dt:maxLength=“255”/> </s:AttributeType> <s:AttributeType name=“c1” rs:name=“Event Filter Class” rs:number=“2” Inventory Solution for Windows Reference 75 Custom Inventory Agent Software Audit Agent Troubleshooting rs:basecolumn=“Event Filter Class” rs:nullable=“true” mifAttrId=“2”> <s:datatype dt:type=“string” dt:maxLength=“255”/> </s:AttributeType> </s:ElementType> </s:Schema> <rs:data> <%set path=“HKEY_LOCAL_MACHINE\SOFTWARE\MICROSOFT\\MSSQLSERVER”%> <%set var1=“reg:%path%\Client\DB-Lib\AutoAnsiToOem”%> <%if %var1%=“ON”%> <%foreach wmiobject=“o” namespace=“ROOT\CIMV2” wql=“select * from __EventFilter”%> <z:row c0=“wmi:o.Name” c1=“wmi:o.__Class”/> <%next%> <%endif%> </rs:data> </xml> </InventoryClass> </InventoryClasses> Example 2: Registry Sub-Key Enumeration <?xml version=“1.0” encoding=“windows-1252”?> <InventoryClasses> <InventoryClass name=“CustInv Sample” manufacturer='CompanyABC' descripion=’ ’ platform='Win32' version='1.0' mifClass='COMPANYABC|CUSTINVSAMPLE|1.0'> <xml xmlns:s=“uuid:BDC6E3F0-6DA3-11d1-A2A3-00AA00C14882” xmlns:dt=“uuid:C2F41010-65B3-11d1-A29F-00AA00C14882” xmlns:rs=“urn:schemas-microsoft-com:rowset” xmlns:z=“#RowsetSchema”> <s:Schema id=“RowsetSchema”> <s:ElementType name=“row” content=“eltOnly” rs:updatable=“true”> <s:AttributeType name=“c0” rs:name=“ClassName” rs:number=“1” rs:basecolumn=“ClassName” rs:keycolumn=“true” mifAttrId=“1”> <s:datatype dt:type=“string” dt:maxLength=“255”/> </s:AttributeType> <s:AttributeType name=“c1” rs:name=“IpsecId” rs:number=“2” rs:basecolumn=“IpsecId” rs:nullable=“true” mifAttrId=“2”> <s:datatype dt:type=“string” dt:maxLength=“255”/> </s:AttributeType> </s:ElementType> </s:Schema> <rs:data> <%set path=“HKEY_LOCAL_MACHINE\SOFTWARE\ALTIRIS\EXPRESS”%> <%set var1=“reg:%path%\Altiris Agent\VERSION”%> <%if %var1% like “?.0.0.?”%> <%foreach regkey=“key1” path=“HKEY_LOCAL_MACHINE\SOFTWARE\Policies\Microsoft\Windows\IPSec\Policy\Local”%> <z:row c0=“key:key1.ClassName” c1=“key:key1.ipsecid”/> <%next%> <%endif%> </rs:data> </xml> </InventoryClass> </InventoryClasses> Example 3: Registry and INI Files <?xml version=“1.0” encoding=“windows-1252”?> <InventoryClasses> <InventoryClass name=“CustInv Sample” manufacturer='CompanyABC' descripion=’ ’ platform='Win32' version='1.0' mifClass='COMPANYABC|CUSTINVSAMPLE|1.0'> <xml xmlns:s=“uuid:BDC6E3F0-6DA3-11d1-A2A3-00AA00C14882” xmlns:dt=“uuid:C2F41010-65B3-11d1-A29F-00AA00C14882” xmlns:rs=“urn:schemas-microsoft-com:rowset” xmlns:z=”#RowsetSchema”> <s:Schema id=“RowsetSchema”> <s:ElementType name=“row” content=“eltOnly” rs:updatable=“true”> <s:AttributeType name=“c0” rs:name=“Auto ANSI to OEM” rs:number=“1” rs:basecolumn=“Auto ANSI to OEM” rs:keycolumn=“true” mifAttrId=“1”> <s:datatype dt:type=“string” dt:maxLength=“10”/> </s:AttributeType> <s:AttributeType name=“c1” rs:name=“Use Intl Settings” rs:number=“2” Inventory Solution for Windows Reference 76 Custom Inventory Agent Software Audit Agent Troubleshooting rs:basecolumn=“Use Intl Settings” rs:nullable=“true” mifAttrId=“2”> <s:datatype dt:type=“string” dt:maxLength=“10”/> </s:AttributeType> <s:AttributeType name=“c2” rs:name=“SQL Server Version” rs:number=“3” rs:basecolumn=“SQL Server Version” rs:nullable=“true” mifAttrId=“3”> <s:datatype dt:type=“string” dt:maxLength=“15”/> </s:AttributeType> </s:ElementType> </s:Schema> <rs:data> <%set filepath=“C:\Program Files\Altiris\Notification Server\NSCap\ Bin\Win32\X86\ExchPls.ini”%> <%set path=“HKEY_LOCAL_MACHINE\SOFTWARE\\MICROSOFT\MSSQLSERVER”%> <z:row c0=“<%write “reg:%path%\Client\DB-Lib\AutoAnsiToOem”%>” c1=“<%write “reg:%path%\Client\DB-Lib\UseIntlSettings”%>” c2=“<%write “reg:%path%\MSSQLSERVER\CurrentVersion\CurrentVersion”%>” /> </rs:data> </xml> </InventoryClass> </InventoryClasses> Example 4a: Reading File Header Information <?xml version=“1.0” encoding=“windows-1252”?> <InventoryClasses> <InventoryClass name=“Windows Server Version” manufacturer='CompanyABC' description='' platform='Win32' version='1.0' mifClass='CompanyABC|Win_Serv_Ver|1.0'> <xml xmlns:s=“uuid:BDC6E3F0-6DA3-11d1-A2A3-00AA00C14882” xmlns:dt=“uuid:C2F4101065B3-11d1-A29F-00AA00C14882” xmlns:rs=“urn:schemas-microsoft-com:rowset” xmlns:z=“#RowsetSchema”> <s:Schema id=“RowsetSchema”> <s:ElementType name=“row” content=“eltOnly” rs:updatable=“true”> <s:AttributeType name=“c0” rs:name=“Modified_Date” rs:number=“1” rs:keycolumn=“true” mifAttrId=“1”> <s:datatype dt:type=“string” dt:maxLength=“30”/> </s:AttributeType> <s:AttributeType name=“c1” rs:name=“File_Size” rs:number=“2” rs:nullable=“true” mifAttrId=“2”> <s:datatype dt:type=“int” dt:maxLength=“4”/> </s:AttributeType> </s:ElementType> </s:Schema> <rs:data> <%set filepath=“%windir%\lanmannt.bmp”%> <z:row c0=“<%writexml “file:%filepath%|Modified_Date”%>” c1=“<%writexml “file:%filepath%|FileSize”%>” /> </rs:data> </xml> </InventoryClass> </InventoryClasses> Example 4b: Reading File Header Information <%set filepath=“reg:HKEY_LOCAL_MACHINE\Software\Microsoft\MediaPlayer\Installation Directory”%> <%set var1=“file:%filepath%\wmplayer.exe|PRODUCT_VERSION”%> <%if %var1%!=“”%> <z:row c0 = “Windows Media Player” c2=“<%writexml “file:%filepath%\wmplayer.exe|PRODUCT_NAME”%>” c3=“<%writexml “file:%filepath%\wmplayer.exe|PRODUCT_VERSION”%>” c8=“<%writexml “file:%filepath%\wmplayer.exe|PATH”%>” /> <%endif%> <%if %var1%=“”%> <%set var1=“file:%filepath%\mplayer2.exe|PRODUCT_VERSION”%> <%endif%> <%if %var1%!=“”%> <z:row Inventory Solution for Windows Reference 77 Custom Inventory Agent Software Audit Agent Troubleshooting c0 = “Windows Media Player” c2=“<%writexml “file:%filepath%\mplayer2.exe|PRODUCT_NAME”%>” c3=“<%writexml “file:%filepath%\mplayer2.exe|PRODUCT_VERSION”%>” c8=“<%writexml “file:%filepath%\mplayer2.exe|PATH”%>” /> <%endif%> Example 4c: Reading File Header Information <?xml version=“1.0” encoding=“windows-1252”?> <InventoryClasses> <InventoryClass name='Registered Files' manufacturer='CompanyABC' description='' version='1.0' platform='Win32' mifClass='CompanyABC|REGFILES|1.0'> <xml xmlns:s=“uuid:BDC6E3F0-6DA3-11d1-A2A3-00AA00C14882” xmlns:dt=“uuid:C2F41010-65B311d1-A29F-00AA00C14882” xmlns:rs=“urn:schemas-microsoft-com:rowset” xmlns:z=“#RowsetSchema”> <s:Schema id=“RowsetSchema”> <s:ElementType name=“row” content=“eltOnly” rs:updatable=“true”> <s:AttributeType name=“c0” rs:name=“Reg Path” rs:number=“1” rs:basecolumn=“Auto Path” rs:keycolumn=“true” mifAttrId='1'> <s:datatype dt:type=“string” dt:maxLength=“255”/> </s:AttributeType> <s:AttributeType name=“c1” rs:name=“Filename in Registry” rs:number=“2” rs:basecolumn=“Filename in Registry” rs:keycolumn=“true” mifAttrId='2'> <s:datatype dt:type=“string” dt:maxLength=“255”/> </s:AttributeType> <s:AttributeType name=“c2” rs:name=“Filename” rs:number=“3” rs:basecolumn=“Filename” rs:keycolumn=“true” mifAttrId='3'> <s:datatype dt:type=“string” dt:maxLength=“255”/> </s:AttributeType> <s:AttributeType name=“c3” rs:name=“Product Name” rs:number=“4” rs:basecolumn=“Product Name” rs:keycolumn=“true” mifAttrId='4'> <s:datatype dt:type=“string” dt:maxLength=“255”/> </s:AttributeType> <s:AttributeType name=“c4” rs:name=“Product Version” rs:number=“5” rs:basecolumn=“Product Version” rs:keycolumn=“true” mifAttrId='5'> <s:datatype dt:type=“string” dt:maxLength=“255”/> </s:AttributeType> <s:AttributeType name=“c5” rs:name=“Manufacturer” rs:number=“6” rs:basecolumn=“Manufacturer” rs:keycolumn=“true” mifAttrId='6'> <s:datatype dt:type=“string” dt:maxLength=“255”/> </s:AttributeType> <s:AttributeType name=“c6” rs:name=“Language” rs:number=“7” rs:basecolumn=“Language” rs:keycolumn=“true” mifAttrId='7'> <s:datatype dt:type=“string” dt:maxLength=“255”/> </s:AttributeType> <s:AttributeType name=“c7” rs:name=“Internal Name” rs:number=“8” rs:basecolumn=“Internal Name” rs:keycolumn=“true” mifAttrId='8'> <s:datatype dt:type=“string” dt:maxLength=“255”/> </s:AttributeType> <s:AttributeType name=“c8” rs:name=“FileSize” rs:number=“9” rs:basecolumn=“FileSize” rs:keycolumn=“true” mifAttrId='9'> <s:datatype dt:type=“string” dt:maxLength=“255”/> </s:AttributeType> <s:AttributeType name=“c9” rs:name=“Path” rs:number=“10” rs:basecolumn=“Path” rs:keycolumn=“true” mifAttrId='10'> <s:datatype dt:type=“string” dt:maxLength=“255”/> </s:AttributeType> <s:AttributeType name=“c10” rs:name=“Creation Date” rs:number=“11” rs:basecolumn=“Creation Date” rs:keycolumn=“true” mifAttrId='11'> <s:datatype dt:type=“string” dt:maxLength=“255”/> </s:AttributeType> <s:AttributeType name=“c11” rs:name=“Last Modified Date” rs:number=“12” rs:basecolumn=“Last Modified Date” rs:keycolumn=“true” mifAttrId='12'> <s:datatype dt:type=“string” dt:maxLength=“255”/> </s:AttributeType> <s:AttributeType name=“c12” rs:name=“Description” rs:number=“13” rs:basecolumn=“Description” rs:keycolumn=“true” mifAttrId='13'> <s:datatype dt:type=“string” dt:maxLength=“255”/> </s:AttributeType> <s:AttributeType name=“c13” rs:name=“Copyright” rs:number=“14” rs:basecolumn=“Copyright” rs:keycolumn=“true” mifAttrId='14'> <s:datatype dt:type=“string” dt:maxLength=“255”/> Inventory Solution for Windows Reference 78 Custom Inventory Agent Software Audit Agent Troubleshooting </s:AttributeType> <s:AttributeType name=“c14” rs:name=“Is Attribute Hidden” rs:number=“15” rs:basecolumn=“Is Attribute Hidden” rs:keycolumn=“true” mifAttrId='15'> <s:datatype dt:type=“string” dt:maxLength=“255”/> </s:AttributeType> <s:AttributeType name=“c15” rs:name=“Is Attribute Read Only” rs:number=“16” rs:basecolumn=“Is Attribute Read Only” rs:keycolumn=“true” mifAttrId='16'> <s:datatype dt:type=“string” dt:maxLength=“255”/> </s:AttributeType> <s:AttributeType name=“c16” rs:name=“Is Attribute System” rs:number=“17” rs:basecolumn=“Is Attribute System” rs:keycolumn=“true” mifAttrId='17'> <s:datatype dt:type=“string” dt:maxLength=“255”/> </s:AttributeType> </s:ElementType> </s:Schema> <rs:data> <%set THROTTLEEVERY=“3”%> <%set SLEEPMS=“40”%> <%set BASEPATH=“HKEY_CLASSES_ROOT\CLSID”%> <%foreach regkey=“key1” throttle=“%THROTTLEEVERY%,%SLEEPMS%” path=“%BASEPATH%”%> <%set SUBKEY=“%BASEPATH%\key:key1.%keyname%”%> <%foreach regkey=“key2” path=“%SUBKEY%” maxIO=“100000000000000”%> <%if key:key2.%keyname%=“InProcServer32”%> <%set FILELOCATION=“key:key2.%default%”%> <%if %FILELOCATION% != “”%> <z:row c0=“<%writexml “%SUBKEY%\key:key2.%keyname%”%>” c1=“<%writexml “%FILELOCATION%”%>” c2=“<%writexml “file:%FILELOCATION%|FILENAME”%>” c3=“<%writexml “file:%FILELOCATION%|PRODUCT_NAME”%>” c4=“<%writexml “file:%FILELOCATION%|PRODUCT_VERSION”%>” c5=“<%writexml “file:%FILELOCATION%|MANUFACTURER”%>” c6=“<%writexml “file:%FILELOCATION%|LANGUAGE”%>” c7=“<%writexml “file:%FILELOCATION%|INTERNAL_NAME”%>” c8=“<%writexml “file:%FILELOCATION%|FILESIZE”%>” c9=“<%writexml “file:%FILELOCATION%|PATH”%>” c10=“<%writexml “file:%FILELOCATION%|ORIGINAL_DATE”%>” c11=“<%writexml “file:%FILELOCATION%|MODIFIED_DATE”%>” c12=“<%writexml “file:%FILELOCATION%|DESCRIPTION”%>” c13=“<%writexml “file:%FILELOCATION%|COPYRIGHT”%>” c14=“<%writexml “file:%FILELOCATION%|IS_ATTR_HIDDEN”%>” c15=“<%writexml “file:%FILELOCATION%|IS_ATTR_READONLY”%>” c16=“<%writexml “file:%FILELOCATION%|IS_ATTR_SYSTEM”%>” /> <%endif%> <%endif%> <%next%> <%next%> </rs:data> </xml> </InventoryClass> </InventoryClasses> Example 5: FOREACH FILE loop to list all ocx files in the Windir and Subdirs <?xml version=”1.0” encoding=”windows-1252”?> <InventoryClasses> <InventoryClass name='All OCX Files in Windir and subdirs' manufacturer='Altiris' description='' version='1.0' platform='Win32' mifClass='ALTIRIS|REGFILES|1.0'> <xml xmlns:s=”uuid:BDC6E3F0-6DA3-11d1-A2A3-00AA00C14882” xmlns:dt=”uuid:C2F41010-65B311d1-A29F-00AA00C14882” xmlns:rs=”urn:schemas-microsoft-com:rowset” xmlns:z=”#RowsetSchema”> <s:Schema id=”RowsetSchema”> <s:ElementType name=”row” content=”eltOnly” rs:updatable=”true”> <s:AttributeType name=”c0” rs:name=”Filename” rs:number=”1” rs:basecolumn=”Filename” rs:keycolumn=”true” mifAttrId='1'> <s:datatype dt:type=”string” dt:maxLength=”255”/> </s:AttributeType> <s:AttributeType name=”c1” rs:name=”Product Name” rs:number=”2” rs:basecolumn=”Product Name” rs:keycolumn=”true” mifAttrId='2'> <s:datatype dt:type=”string” dt:maxLength=”255”/> Inventory Solution for Windows Reference 79 Custom Inventory Agent Software Audit Agent Troubleshooting </s:AttributeType> <s:AttributeType name=”c2” rs:name=”Product Version” rs:number=”3” rs:basecolumn=”Product Version” rs:keycolumn=”true” mifAttrId='3'> <s:datatype dt:type=”string” dt:maxLength=”255”/> </s:AttributeType> <s:AttributeType name=”c3” rs:name=”Manufacturer” rs:number=”4” rs:basecolumn=”Manufacturer” rs:keycolumn=”true” mifAttrId='4'> <s:datatype dt:type=”string” dt:maxLength=”255”/> </s:AttributeType> <s:AttributeType name=”c4” rs:name=”Language” rs:number=”5” rs:basecolumn=”Language” rs:keycolumn=”true” mifAttrId='5'> <s:datatype dt:type=”string” dt:maxLength=”255”/> </s:AttributeType> <s:AttributeType name=”c5” rs:name=”Internal Name” rs:number=”6” rs:basecolumn=”Internal Name” rs:keycolumn=”true” mifAttrId='6'> <s:datatype dt:type=”string” dt:maxLength=”255”/> </s:AttributeType> <s:AttributeType name=”c6” rs:name=”FileSize” rs:number=”7” rs:basecolumn=”FileSize” rs:keycolumn=”true” mifAttrId='7'> <s:datatype dt:type=”string” dt:maxLength=”255”/> </s:AttributeType> <s:AttributeType name=”c7” rs:name=”Path” rs:number=”8” rs:basecolumn=”Path” rs:keycolumn=”true” mifAttrId='8'> <s:datatype dt:type=”string” dt:maxLength=”255”/> </s:AttributeType> <s:AttributeType name=”c8” rs:name=”Creation Date” rs:number=”9” rs:basecolumn=”Creation Date” rs:keycolumn=”true” mifAttrId='9'> <s:datatype dt:type=”string” dt:maxLength=”255”/> </s:AttributeType> <s:AttributeType name=”c9” rs:name=”Last Modified Date” rs:number=”10” rs:basecolumn=”Last Modified Date” rs:keycolumn=”true” mifAttrId='10'> <s:datatype dt:type=”string” dt:maxLength=”255”/> </s:AttributeType> <s:AttributeType name=”c10” rs:name=”Description” rs:number=”11” rs:basecolumn=”Description” rs:keycolumn=”true” mifAttrId='11'> <s:datatype dt:type=”string” dt:maxLength=”255”/> </s:AttributeType> <s:AttributeType name=”c11” rs:name=”Copyright” rs:number=”12” rs:basecolumn=”Copyright” rs:keycolumn=”true” mifAttrId='12'> <s:datatype dt:type=”string” dt:maxLength=”255”/> </s:AttributeType> <s:AttributeType name=”c12” rs:name=”Is Attribute Hidden” rs:number=”13” rs:basecolumn=”Is Attribute Hidden” rs:keycolumn=”true” mifAttrId='13'> <s:datatype dt:type=”string” dt:maxLength=”255”/> </s:AttributeType> <s:AttributeType name=”c13” rs:name=”Is Attribute Read Only” rs:number=”14” rs:basecolumn=”Is Attribute Read Only” rs:keycolumn=”true” mifAttrId='14'> <s:datatype dt:type=”string” dt:maxLength=”255”/> </s:AttributeType> <s:AttributeType name=”c14” rs:name=”Is Attribute System” rs:number=”15” rs:basecolumn=”Is Attribute System” rs:keycolumn=”true” mifAttrId='15'> <s:datatype dt:type=”string” dt:maxLength=”255”/> </s:AttributeType> <s:AttributeType name=”c15” rs:name=”Is Windows System Protected” rs:number=”16” rs:basecolumn=”Is Windows System Protected” rs:keycolumn=”true” mifAttrId='16'> <s:datatype dt:type=”string” dt:maxLength=”255”/> </s:AttributeType> </s:ElementType> </s:Schema> <rs:data> <%set THROTTLEEVERY=”30”%> <%set SLEEPMS=”30”%> <%foreach file=”file1” subdirs=”yes” throttle=”%THROTTLEEVERY%,%SLEEPMS%” path=”%windir%\*.ocx” maxIO=”5000”%> <z:row c0=”<%writexml “forfile:file1.FILENAME”%>” c1=”<%writexml “forfile:file1.PRODUCT_NAME”%>” c2=”<%writexml “forfile:file1.PRODUCT_VERSION”%>” c3=”<%writexml “forfile:file1.MANUFACTURER”%>” c4=”<%writexml “forfile:file1.LANGUAGE”%>” c5=”<%writexml “forfile:file1.INTERNAL_NAME”%>” c6=”<%writexml “forfile:file1.FILESIZE”%>” c7=”<%writexml “forfile:file1.PATH”%>” c8=”<%writexml “forfile:file1.ORIGINAL_DATE”%>” Inventory Solution for Windows Reference 80 Custom Inventory Agent Software Audit Agent Troubleshooting c9=”<%writexml “forfile:file1.MODIFIED_DATE”%>” c10=”<%writexml “forfile:file1.DESCRIPTION”%>” c11=”<%writexml “forfile:file1.COPYRIGHT”%>” c12=”<%writexml “forfile:file1.IS_ATTR_HIDDEN”%>” c13=”<%writexml “forfile:file1.IS_ATTR_READONLY”%>” c14=”<%writexml “forfile:file1.IS_ATTR_SYSTEM”%>” c15=”<%writexml “forfile:file1.IS_SYSTEM_PROTECTED”%>” /> <%next%> </rs:data> </xml> </InventoryClass> </InventoryClasses> Example 6: Enumerating VALUES of a Single Registry Key <?xml version=”1.0” encoding=”windows-1252”?> <InventoryClasses> <InventoryClass name=”CustInv Sample” manufacturer='CompanyABC' description='' platform='Win32' version='1.0' mifClass='COMPANYABC|CUSTINVSAMPLE|1.0'> <xml xmlns:s=”uuid:BDC6E3F0-6DA3-11d1-A2A3-00AA00C14882” xmlns:dt=”uuid:C2F4101065B3-11d1-A29F-00AA00C14882” xmlns:rs=”urn:schemas-microsoft-com:rowset” xmlns:z=”#RowsetSchema”> <s:Schema id=”RowsetSchema”> <s:ElementType name=”row” content=”eltOnly” rs:updatable=”true”> <s:AttributeType name=”c0” rs:name=”Name” rs:number=”1” rs:keycolumn=”true” mifAttrId=”1”> <s:datatype dt:type=”string” dt:maxLength=”255”/> </s:AttributeType> <s:AttributeType name=”c1” rs:name=”type” rs:number=”2” rs:nullable=”true” mifAttrId=”2”> <s:datatype dt:type=”string” dt:maxLength=”255”/> </s:AttributeType> <s:AttributeType name=”c2” rs:name=”Value” rs:number=”3” rs:nullable=”true” mifAttrId=”3”> <s:datatype dt:type=”string” dt:maxLength=”255”/> </s:AttributeType> </s:ElementType> </s:Schema> <rs:data> <%set RegPath=”HKEY_LOCAL_MACHINE\SOFTWARE\Altiris\eXpress\Notification Server\Solutions\{3AD26790-F471-11F2-8246-0F101B34B9DF}”%> <%foreach regvalue=”val1” path=”%RegPath%”%> <z:row c0=”<%writexml “key:val1.name”%>” c1=”<%writexml “key:val1.type”%>” c2=”<%writexml “key:val1.value”%>” /> <%next%> </rs:data> </xml> </InventoryClass> </InventoryClasses> Inventory Solution for Windows Reference 81 Exchange Agent Software Audit Agent Troubleshooting Exchange Agent The Exchange agent scans mail profile information and adds this information to your database. The Exchange agent gathers information from the Exchange Server directory and associates the Exchange mailbox properties with the local computer's inventory in the database through the creation of a MIF or NSI file. With the Exchange agent, you can customize the set of properties that are scanned from the Exchange server directory and added to the database. You can also customize the names of the properties so that the data appears in your database just as you would like it to appear. For example, there is a property in the Exchange directory called Custom Attribute 1. If you use this property in your Exchange server implementation to specify the employee cost center, then in the MIF or NSI file created by the Exchange agent you can set the name of the attribute to be Cost Center. Cost Center then is the name of the attribute as seen in the Resource Explorer. The Exchange agent also works with Microsoft Exchange 2000 in an Active Directory environment. Note: The user must be logged on to the computer for the Exchange Agent to work correctly. Note: If users have Microsoft Outlook on the target computer and they are a low-rights user, the Exchange agent will still work. Read rights will be granted so the data can be gathered. Quick Links • “How the Exchange Agent Works” on page 82 • “Exchange Agent Configuration” on page 82 • “Customizing the Data Reported” on page 82 • “Exchange Agent Administration” on page 83 • “Exchange Agent Troubleshooting” on page 84 How the Exchange Agent Works The Exchange agent enumerates each mail profile that is defined on the computer. For each profile, the set of mail providers is returned. If the Microsoft Exchange Server is one of the mail providers in a profile, then Exchange agent gathers information about the mailbox that the profile is set up to read. This information is then converted to a MIF or NSI file that is registered with the target computer. Depending on the file type, the Exchange agent does one of the following: • Places a MIF file called exchpls.mif in the NOIDMIF directory on the target computer. • Places an NSI file in the install path\Altiris\express\Inventory folder. Exchange Agent Configuration • “Customizing the Data Reported” on page 82 • “Exchange Agent Administration” on page 83 • “Exchange Agent Troubleshooting” on page 84 Customizing the Data Reported The default exchpls.ini file that is shipped with the Exchange agent contains the configuration to gather the most commonly requested settings out of the Exchange directory. Normally you don't need to customize the exchpls.ini file from the default settings. Inventory Solution for Windows Reference 82 Exchange Agent Software Audit Agent Troubleshooting However, if you do want to gather additional data or change the names of attributes as they appear in the SMS database, the exchpls.ini file has the following format: [Exch EMail Property.7] # PR_STREET_ADDRESS, Attribute Tag = 0x3A29001E Attribute Name = Street Address Attribute ID = 7 Each section is of the format [Exch EMail Property.<index>] where <index> is some unique positive integer. If the <index> is not unique, then only a single instance of the <index> will be processed. Lines that start with # are comments. Other characters in the line are ignored. The Attribute Tag is a HEX value which corresponds to the ID of the property that is to be gathered from the Exchange directory. The format of the string is 0x plus the rest of the HEX value. The Attribute Name is the value of the attribute name that is generated in the exchpls.mif file The Attribute ID is the Decimal ID of the attribute that is generated in the exchpls.mif file. The attributes are output in the exchpls.mif in the order they appear in the exchpls.ini file. This order is not significant to SMS. The Attribute Name and the Attribute ID are significant to SMS. Also, note that the Attribute Tag is in HEX and the Attribute ID is in Decimal. Note: For a complete list of the attributes that are available to be gathered from the Exchange directory, see “Appendix A: Exchange Directory Values” on page 88. IMPORTANT: After you have associated a given attribute tag and attribute name with a given attribute ID, you cannot easily change this without causing issues in SMS. When SMS has processed a MIF with a given context for a given attribute ID, all future MIFs of that group are expected to retain the same attribute name and context for that ID. When a MIF is processed by SMS there is a history file that is created. This history file contains the context of what MIF attribute names are associated with which MIF attribute IDs for a given MIF group class. If you create new MIF files that change this data, SMS will report an error when processing the MIF even though the MIF file does not have any syntax errors. If you want to change what data is reported or the names of attributes, you should change both the Attribute Name as well as the Attribute ID so that they are distinct from all other Attribute Names and Attribute IDs that have previously been used for that group class. IMPORTANT: There are two hard coded attribute names and IDs that are always generated for a group when the Exchange agent runs. These are: START ATTRIBUTE Name = “Profile” ID = 98 Type = String(256) Access = Read-Only Storage = Specific Value = “Some Profile Name” END ATTRIBUTE START ATTRIBUTE Name = “Default Profile” ID = 99 Type = String(256) Access = Read-Only Storage = Specific Value = “Yes” END ATTRIBUTE Note: Do not use these attribute IDs in your own defined sections in the exchpls.ini file. Exchange Agent Administration For Exchange agent to properly run, the file AeXExchPls.ini must exist in the same directory as the AeXExchPls.exe file. The AeXExchPls.ini file specifies the set of Exchange directory attributes that are to be gathered and written in the AeXExchPls.mif file. If the AeXExchPls.ini file does not exist Inventory Solution for Windows Reference 83 Exchange Agent Software Audit Agent Troubleshooting in the same directory as AeXExchPls.exe, then you will get an error dialog indicating that the INI file cannot be found. If the INI file is not properly formatted, then you may get other error messages indicating various issues in trying to interpret the contents of the INI file. If you run the Exchange agent in hidden mode, then any error messages about a missing or badly formed AeXExchPls.ini file are not presented to the user, and no MIF file is created. Command Line Arguments for the Exchange agent For a listing of the Exchange agent command line arguments, see “AeXExchPls Executable” on page 97. Exchange Agent Troubleshooting • Use the /? command line argument when running Exchange agent to get the usage details. • MIF files will be created in the NOIDMIF directory and an NSI file will be created in install path \Altiris\express\Inventory. • The user must be on the network to get data from the directory. If Outlook has not run on Windows 2000 and the user is not an administrator, you may not be able to get user data. Inventory Solution for Windows Reference 84 Serial Number Agent Software Audit Agent Troubleshooting Serial Number Agent The Serial Number agent reports detailed information about the serial number, computer model and manufacturer, memory modules, SMBIOS, and BIOS. This provides a great way to track your business assets. How many times has your management asked, “How many of each PC model type do we have?” Or “Where did all that memory we purchased go to?” The Serial Number agent reports these full details. Quick Links • “Serial Number Agent Administration” on page 85 • “Serial Number Agent Troubleshooting” on page 85 Serial Number Agent Administration The default settings of Serial Number (which you can override with the command line arguments) write MIF files to an XML formatted file called snplus.nsi in the install path\Altiris\express\Inventory folder and to the NOIDMIF directory on an SMS client. The NSI file can be viewed with the Altiris NSI file viewer which is included with Notification Server. The reports for the Serial Number agent come with reports that indicate which computers have run Serial Number agent. These reports will also indicate which computers may not be reporting serial number data. When a computer is scanned and no serial number is found, a file called sndata.bin is generated and left in the root of the C: drive on the computer where the scan took place. You can forward this sndata.bin file to Altiris Support through e-mail at support@altiris.com. Altiris Support can analyze the file to see if support can be added to gather the serial number data. Command Line Arguments for the Serial Number agent For a listing of the Serial Number agent command line arguments, see “AeXSNPlus Executable” on page 102. Serial Number Agent Troubleshooting • When a computer is scanned and no information is found, a file called sndata.bin is generated and left in the root of the C: drive on the computer where the scan took place. • Serial Number information is offered by most larger PC manufacturers. There are cases where serial number information is simply not available to be retrieved. A log file will be created to track and identify if the serial number can be extracted. Contact support@altiris.com for details on how to train the Serial Number agent to gather the serial number data from these new computers. Inventory Solution for Windows Reference 85 Machine Inventory Agent Software Audit Agent Troubleshooting Machine Inventory Agent The Machine Inventory agent is used to collect software and hardware inventory. Command Line Arguments for the Machine Inventory agent For a listing of the Machine Inventory command line arguments, see “AeXMachInv Executable” on page 99. To exclude inventory groups from being inventoried, you can create an INI file containing the groups to be excluded. This file should be placed in the same directory as AeXMachInv.exe. For a list of inventory groups, see “Appendix C: Inventory Solution Data Reference” on page 105. Example Suppose you want to exclude the following groups from the Machine Inventory results. • • • • • • AeX EU Logon Users AeX EU Results AeX OS Results AeX OS User Profiles AeX OS Desktop AeX OS Internet Explorer To do this, you first create a file, MachInv.ini, which lists these group names. Then place this file in the same directory as AeXMachInv.exe. MachInv.ini contents: AeX AeX AeX AeX AeX AeX EU EU OS OS OS OS Logon Users Results Results User Profiles Desktop Internet Explorer Next, run AeXMachInv as follows: AeXMachInv /ini MachInv.ini Note: You can include only the files found in the INI file by using the /inc parameter. Inventory Solution for Windows Reference 86 Reference This reference section provides command line arguments and other detailed information you may need when using Inventory Solution. Quick Links “Appendix A: Exchange Directory Values” on page 88 Provides a table of Exchange directory values. “Appendix B: Program Command Line Arguments” on page 95 Provides command line arguments for programs provided by Inventory Solution. “Appendix C: Inventory Solution Provides a list of inventory tables that are found in Data Reference” on page 105 the Notification Server database. Inventory Solution for Windows Reference 87 Appendix A: Exchange Directory Values Property Name HEX Value PR_ACCOUNT 0x3a00001e PR_ACCOUNT_W 0x3a00001f PR_ACCOUNT_A 0x3a00001e PR_ALTERNATE_RECIPIENT 0x3a010102 PR_CALLBACK_TELEPHONE_NUMBER 0x3a02001e PR_CALLBACK_TELEPHONE_NUMBER_W 0x3a02001f PR_CALLBACK_TELEPHONE_NUMBER_A 0x3a02001e PR_CONVERSION_PROHIBITED 0x3a03000b PR_DISCLOSE_RECIPIENTS 0x3a04000b PR_GENERATION 0x3a05001e PR_GENERATION_W 0x3a05001f PR_GENERATION_A 0x3a05001e PR_GIVEN_NAME 0x3a06001e PR_GIVEN_NAME_W 0x3a06001f PR_GIVEN_NAME_A 0x3a06001e PR_GOVERNMENT_ID_NUMBER 0x3a07001e PR_GOVERNMENT_ID_NUMBER_W 0x3a07001f PR_GOVERNMENT_ID_NUMBER_A 0x3a07001e PR_BUSINESS_TELEPHONE_NUMBER 0x3a08001e PR_BUSINESS_TELEPHONE_NUMBER_W 0x3a08001f PR_BUSINESS_TELEPHONE_NUMBER_A 0x3a08001e PR_OFFICE_TELEPHONE_NUMBER 0x3a08001e PR_OFFICE_TELEPHONE_NUMBER_W 0x3a08001f PR_OFFICE_TELEPHONE_NUMBER_A 0x3a08001e PR_HOME_TELEPHONE_NUMBER 0x3a09001e PR_HOME_TELEPHONE_NUMBER_W 0x3a09001f PR_HOME_TELEPHONE_NUMBER_A 0x3a09001e PR_INITIALS 0x3a0a001e PR_INITIALS_W 0x3a0a001f PR_INITIALS_A 0x3a0a001e PR_KEYWORD 0x3a0b001e PR_KEYWORD_W 0x3a0b001f Inventory Solution for Windows Reference 88 Appendix A: Exchange Directory Values PR_KEYWORD_A 0x3a0b001e PR_LANGUAGE 0x3a0c001e PR_LANGUAGE_W 0x3a0c001f PR_LANGUAGE_A 0x3a0c001e PR_LOCATION 0x3a0d001e PR_LOCATION_W 0x3a0d001f PR_LOCATION_A 0x3a0d001e PR_MAIL_PERMISSION 0x3a0e000b PR_MHS_COMMON_NAME 0x3a0f001e PR_MHS_COMMON_NAME_W 0x3a0f001f PR_MHS_COMMON_NAME_A 0x3a0f001e PR_ORGANIZATIONAL_ID_NUMBER 0x3a10001e PR_ORGANIZATIONAL_ID_NUMBER_W 0x3a10001f PR_ORGANIZATIONAL_ID_NUMBER_A 0x3a10001e PR_SURNAME 0x3a11001e PR_SURNAME_W 0x3a11001f PR_SURNAME_A 0x3a11001e PR_ORIGINAL_ENTRYID 0x3a120102 PR_ORIGINAL_DISPLAY_NAME 0x3a13001e PR_ORIGINAL_DISPLAY_NAME_W 0x3a13001f PR_ORIGINAL_DISPLAY_NAME_A 0x3a13001e PR_ORIGINAL_SEARCH_KEY 0x3a140102 PR_POSTAL_ADDRESS 0x3a15001e PR_POSTAL_ADDRESS_W 0x3a15001f PR_POSTAL_ADDRESS_A 0x3a15001e PR_COMPANY_NAME 0x3a16001e PR_COMPANY_NAME_W 0x3a16001f PR_COMPANY_NAME_A 0x3a16001e PR_TITLE 0x3a17001e PR_TITLE_W 0x3a17001f PR_TITLE_A 0x3a17001e PR_DEPARTMENT_NAME 0x3a18001e PR_DEPARTMENT_NAME_W 0x3a18001f PR_DEPARTMENT_NAME_A 0x3a18001e PR_OFFICE_LOCATION 0x3a19001e PR_OFFICE_LOCATION_W 0x3a19001f PR_OFFICE_LOCATION_A 0x3a19001e PR_PRIMARY_TELEPHONE_NUMBER 0x3a1a001e PR_PRIMARY_TELEPHONE_NUMBER_W 0x3a1a001f PR_PRIMARY_TELEPHONE_NUMBER_A 0x3a1a001e PR_BUSINESS2_TELEPHONE_NUMBER 0x3a1b001e PR_BUSINESS2_TELEPHONE_NUMBER_W 0x3a1b001f Inventory Solution for Windows Reference 89 Appendix A: Exchange Directory Values PR_BUSINESS2_TELEPHONE_NUMBER_A 0x3a1b001e PR_OFFICE2_TELEPHONE_NUMBER 0x3a1b001e PR_OFFICE2_TELEPHONE_NUMBER_W 0x3a1b001f PR_OFFICE2_TELEPHONE_NUMBER_A 0x3a1b001e PR_MOBILE_TELEPHONE_NUMBER 0x3a1c001e PR_MOBILE_TELEPHONE_NUMBER_W 0x3a1c001f PR_MOBILE_TELEPHONE_NUMBER_A 0x3a1c001e PR_CELLULAR_TELEPHONE_NUMBER 0x3a1c001e PR_CELLULAR_TELEPHONE_NUMBER_W 0x3a1c001f PR_CELLULAR_TELEPHONE_NUMBER_A 0x3a1c001e PR_RADIO_TELEPHONE_NUMBER 0x3a1d001e PR_RADIO_TELEPHONE_NUMBER_W 0x3a1d001f PR_RADIO_TELEPHONE_NUMBER_A 0x3a1d001e PR_CAR_TELEPHONE_NUMBER 0x3a1e001e PR_CAR_TELEPHONE_NUMBER_W 0x3a1e001f PR_CAR_TELEPHONE_NUMBER_A 0x3a1e001e PR_OTHER_TELEPHONE_NUMBER 0x3a1f001e PR_OTHER_TELEPHONE_NUMBER_W 0x3a1f001f PR_OTHER_TELEPHONE_NUMBER_A 0x3a1f001e PR_TRANSMITABLE_DISPLAY_NAME 0x3a20001e PR_TRANSMITABLE_DISPLAY_NAME_W 0x3a20001f PR_TRANSMITABLE_DISPLAY_NAME_A 0x3a20001e PR_PAGER_TELEPHONE_NUMBER 0x3a21001e PR_PAGER_TELEPHONE_NUMBER_W 0x3a21001f PR_PAGER_TELEPHONE_NUMBER_A 0x3a21001e PR_BEEPER_TELEPHONE_NUMBER 0x3a21001e PR_BEEPER_TELEPHONE_NUMBER_W 0x3a21001f PR_BEEPER_TELEPHONE_NUMBER_A 0x3a21001e PR_USER_CERTIFICATE 0x3a220102 PR_PRIMARY_FAX_NUMBER 0x3a23001e PR_PRIMARY_FAX_NUMBER_W 0x3a23001f PR_PRIMARY_FAX_NUMBER_A 0x3a23001e PR_BUSINESS_FAX_NUMBER 0x3a24001e PR_BUSINESS_FAX_NUMBER_W 0x3a24001f PR_BUSINESS_FAX_NUMBER_A 0x3a24001e PR_HOME_FAX_NUMBER 0x3a25001e PR_HOME_FAX_NUMBER_W 0x3a25001f PR_HOME_FAX_NUMBER_A 0x3a25001e PR_COUNTRY 0x3a26001e PR_COUNTRY_W 0x3a26001f PR_COUNTRY_A 0x3a26001e PR_BUSINESS_ADDRESS_COUNTRY 0x3a26001e Inventory Solution for Windows Reference 90 Appendix A: Exchange Directory Values PR_BUSINESS_ADDRESS_COUNTRY_W 0x3a26001f PR_BUSINESS_ADDRESS_COUNTRY_A 0x3a26001e PR_LOCALITY 0x3a27001e PR_LOCALITY_W 0x3a27001f PR_LOCALITY_A 0x3a27001e PR_BUSINESS_ADDRESS_CITY 0x3a27001e PR_BUSINESS_ADDRESS_CITY_W 0x3a27001f PR_BUSINESS_ADDRESS_CITY_A 0x3a27001e PR_STATE_OR_PROVINCE 0x3a28001e PR_STATE_OR_PROVINCE_W 0x3a28001f PR_STATE_OR_PROVINCE_A 0x3a28001e PR_BUSINESS_ADDRESS_STATE_OR_PROVINCE 0x3a28001e PR_BUSINESS_ADDRESS_STATE_OR_PROVINCE_W 0x3a28001f PR_BUSINESS_ADDRESS_STATE_OR_PROVINCE_A 0x3a28001e PR_STREET_ADDRESS 0x3a29001e PR_STREET_ADDRESS_W 0x3a29001f PR_STREET_ADDRESS_A 0x3a29001e PR_BUSINESS_ADDRESS_STREET 0x3a29001e PR_BUSINESS_ADDRESS_STREET_W 0x3a29001f PR_BUSINESS_ADDRESS_STREET_A 0x3a29001e PR_POSTAL_CODE 0x3a2a001e PR_POSTAL_CODE_W 0x3a2a001f PR_POSTAL_CODE_A 0x3a2a001e PR_BUSINESS_ADDRESS_POSTAL_CODE 0x3a2a001e PR_BUSINESS_ADDRESS_POSTAL_CODE_W 0x3a2a001f PR_BUSINESS_ADDRESS_POSTAL_CODE_A 0x3a2a001e PR_POST_OFFICE_BOX 0x3a2b001e PR_POST_OFFICE_BOX_W 0x3a2b001f PR_POST_OFFICE_BOX_A 0x3a2b001e PR_BUSINESS_ADDRESS_POST_OFFICE_BOX 0x3a2b001e PR_BUSINESS_ADDRESS_POST_OFFICE_BOX_W 0x3a2b001f PR_BUSINESS_ADDRESS_POST_OFFICE_BOX_A 0x3a2b001e PR_TELEX_NUMBER 0x3a2c001e PR_TELEX_NUMBER_W 0x3a2c001f PR_TELEX_NUMBER_A 0x3a2c001e PR_ISDN_NUMBER 0x3a2d001e PR_ISDN_NUMBER_W 0x3a2d001f PR_ISDN_NUMBER_A 0x3a2d001e PR_ASSISTANT_TELEPHONE_NUMBER 0x3a2e001e PR_ASSISTANT_TELEPHONE_NUMBER_W 0x3a2e001f PR_ASSISTANT_TELEPHONE_NUMBER_A 0x3a2e001e PR_HOME2_TELEPHONE_NUMBER 0x3a2f001e Inventory Solution for Windows Reference 91 Appendix A: Exchange Directory Values PR_HOME2_TELEPHONE_NUMBER_W 0x3a2f001f PR_HOME2_TELEPHONE_NUMBER_A 0x3a2f001e PR_ASSISTANT 0x3a30001e PR_ASSISTANT_W 0x3a30001f PR_ASSISTANT_A 0x3a30001e PR_SEND_RICH_INFO 0x3a40000b PR_WEDDING_ANNIVERSARY 0x3a410040 PR_BIRTHDAY 0x3a420040 PR_HOBBIES 0x3a43001e PR_HOBBIES_W 0x3a43001f PR_HOBBIES_A 0x3a43001e PR_MIDDLE_NAME 0x3a44001e PR_MIDDLE_NAME_W 0x3a44001f PR_MIDDLE_NAME_A 0x3a44001e PR_DISPLAY_NAME_PREFIX 0x3a45001e PR_DISPLAY_NAME_PREFIX_W 0x3a45001f PR_DISPLAY_NAME_PREFIX_A 0x3a45001e PR_PROFESSION 0x3a46001e PR_PROFESSION_W 0x3a46001f PR_PROFESSION_A 0x3a46001e PR_PREFERRED_BY_NAME 0x3a47001e PR_PREFERRED_BY_NAME_W 0x3a47001f PR_PREFERRED_BY_NAME_A 0x3a47001e PR_SPOUSE_NAME 0x3a48001e PR_SPOUSE_NAME_W 0x3a48001f PR_SPOUSE_NAME_A 0x3a48001e PR_COMPUTER_NETWORK_NAME 0x3a49001e PR_COMPUTER_NETWORK_NAME_W 0x3a49001f PR_COMPUTER_NETWORK_NAME_A 0x3a49001e PR_CUSTOMER_ID 0x3a4a001e PR_CUSTOMER_ID_W 0x3a4a001f PR_CUSTOMER_ID_A 0x3a4a001e PR_TTYTDD_PHONE_NUMBER 0x3a4b001e PR_TTYTDD_PHONE_NUMBER_W 0x3a4b001f PR_TTYTDD_PHONE_NUMBER_A 0x3a4b001e PR_FTP_SITE 0x3a4c001e PR_FTP_SITE_W 0x3a4c001f PR_FTP_SITE_A 0x3a4c001e PR_GENDER 0x3a4d0002 PR_MANAGER_NAME 0x3a4e001e PR_MANAGER_NAME_W 0x3a4e001f PR_MANAGER_NAME_A 0x3a4e001e Inventory Solution for Windows Reference 92 Appendix A: Exchange Directory Values PR_NICKNAME 0x3a4f001e PR_NICKNAME_W 0x3a4f001f PR_NICKNAME_A 0x3a4f001e PR_PERSONAL_HOME_PAGE 0x3a50001e PR_PERSONAL_HOME_PAGE_W 0x3a50001f PR_PERSONAL_HOME_PAGE_A 0x3a50001e PR_BUSINESS_HOME_PAGE 0x3a51001e PR_BUSINESS_HOME_PAGE_W 0x3a51001f PR_BUSINESS_HOME_PAGE_A 0x3a51001e PR_CONTACT_VERSION 0x3a520048 PR_CONTACT_ENTRYIDS 0x3a531102 PR_CONTACT_ADDRTYPES 0x3a54101e PR_CONTACT_ADDRTYPES_W 0x3a54101f PR_CONTACT_ADDRTYPES_A 0x3a54101e PR_CONTACT_DEFAULT_ADDRESS_INDEX 0x3a550003 PR_CONTACT_EMAIL_ADDRESSES 0x3a56101e PR_CONTACT_EMAIL_ADDRESSES_W 0x3a56101f PR_CONTACT_EMAIL_ADDRESSES_A 0x3a56101e PR_COMPANY_MAIN_PHONE_NUMBER 0x3a57001e PR_COMPANY_MAIN_PHONE_NUMBER_W 0x3a57001f PR_COMPANY_MAIN_PHONE_NUMBER_A 0x3a57001e PR_CHILDRENS_NAMES 0x3a58101e PR_CHILDRENS_NAMES_W 0x3a58101f PR_CHILDRENS_NAMES_A 0x3a58101e PR_HOME_ADDRESS_CITY 0x3a59001e PR_HOME_ADDRESS_CITY_W 0x3a59001f PR_HOME_ADDRESS_CITY_A 0x3a59001e PR_HOME_ADDRESS_COUNTRY 0x3a5a001e PR_HOME_ADDRESS_COUNTRY_W 0x3a5a001f PR_HOME_ADDRESS_COUNTRY_A 0x3a5a001e PR_HOME_ADDRESS_POSTAL_CODE 0x3a5b001e PR_HOME_ADDRESS_POSTAL_CODE_W 0x3a5b001f PR_HOME_ADDRESS_POSTAL_CODE_A 0x3a5b001e PR_HOME_ADDRESS_STATE_OR_PROVINCE 0x3a5c001e PR_HOME_ADDRESS_STATE_OR_PROVINCE_W 0x3a5c001f PR_HOME_ADDRESS_STATE_OR_PROVINCE_A 0x3a5c001e PR_HOME_ADDRESS_STREET 0x3a5d001e PR_HOME_ADDRESS_STREET_W 0x3a5d001f PR_HOME_ADDRESS_STREET_A 0x3a5d001e PR_HOME_ADDRESS_POST_OFFICE_BOX 0x3a5e001e PR_HOME_ADDRESS_POST_OFFICE_BOX_W 0x3a5e001f PR_HOME_ADDRESS_POST_OFFICE_BOX_A 0x3a5e001e Inventory Solution for Windows Reference 93 Appendix A: Exchange Directory Values PR_OTHER_ADDRESS_CITY 0x3a5f001e PR_OTHER_ADDRESS_CITY_W 0x3a5f001f PR_OTHER_ADDRESS_CITY_A 0x3a5f001e PR_OTHER_ADDRESS_COUNTRY 0x3a60001e PR_OTHER_ADDRESS_COUNTRY_W 0x3a60001f PR_OTHER_ADDRESS_COUNTRY_A 0x3a60001e PR_OTHER_ADDRESS_POSTAL_CODE 0x3a61001e PR_OTHER_ADDRESS_POSTAL_CODE_W 0x3a61001f PR_OTHER_ADDRESS_POSTAL_CODE_A 0x3a61001e PR_OTHER_ADDRESS_STATE_OR_PROVINCE 0x3a62001e PR_OTHER_ADDRESS_STATE_OR_PROVINCE_W 0x3a62001f PR_OTHER_ADDRESS_STATE_OR_PROVINCE_A 0x3a62001e PR_OTHER_ADDRESS_STREET 0x3a63001e PR_OTHER_ADDRESS_STREET_W 0x3a63001f PR_OTHER_ADDRESS_STREET_A 0x3a63001e PR_OTHER_ADDRESS_POST_OFFICE_BOX 0x3a64001e PR_OTHER_ADDRESS_POST_OFFICE_BOX_W 0x3a64001f PR_OTHER_ADDRESS_POST_OFFICE_BOX_A 0x3a64001e Inventory Solution for Windows Reference 94 Appendix B: Program Command Line Arguments This appendix is a quick reference of the programs found in the Altiris Inventory Solution Reference. These programs are: • “AeXAuditpls Executable” on page 95 • “AeXCustInv Executable” on page 96 • “AeXExchPls Executable” on page 97 • “AeXInvSoln Executable” on page 98 • “AeXMachInv Executable” on page 99 • “AeXNSInvCollector Executable” on page 99 • “AeXRunControl Executable” on page 101 • “AeXSNPlus Executable” on page 102 AeXAuditpls Executable For more information on the Audit agent, see “Input for the Software Audit Agent” on page 50. AeXAuditpls [/?] [/ini filename] [/hidden] [/file] [/dd] [/output format] [/o path] AeXAuditpls Parameters Parameter Description ? Shows a usage dialog. ini filename If this argument is set, Audit uses the user-supplied file, filename, as the Audit INI file rather than the default file. The default file name is auditpls.ini and is found in the same directory as AeXAuditpls. The filename may be relative or absolute. • If the /ini argument is used without a file name, Audit will not run. • If execution was attempted in hidden mode (see /hidden argument), the program exits without notification. • If execution is in the default non-hidden mode, an error dialog is displayed indicating an INI file name error. hidden Makes the progress dialog invisible. End users will not be able to cancel the scan unless they kill the process with Task Manager. This is the argument that is usually used when running the agent as it ensures that it will run on the computer without the user canceling the scan. Inventory Solution for Windows Reference 95 Appendix B: Program Command Line Arguments AeXAuditpls Parameters Parameter Description file Audits individual files rather than packages. Auditing in package mode is the default. There is no explicit packages argument. • In the Package mode, only one file from each package will be added to the output. This is the first instance of a file with a unique manufacturer, product name, language, and (optionally) version. • In the File mode, each file will be added to the output, even if other files for the same product name and version have already been reported. Generally the Package mode should be used as this results in a much smaller output file being created. File mode is used for gathering version resource information for all the files on the computer. dd Delayed dismiss. This only works in non-hidden mode and causes a message box to be opened at the end of the run. The user has an indefinite period to examine data. Without the /dd argument, the user has 4 seconds after the beep (after the run) to examine data, then the window automatically closes. output format The possible values are XML, MIF, or both. These settings override settings defined in the auditpls.ini file. XML output data is used for real time viewing of the results. XML format is also used to load the data into Notification Server. MIF output is used by SMS. An SMS client must be configured on the computer for MIF output to be generated. o path The directory where XML output data should be generated. This setting is ignored if the output is configured for MIF only. This takes precedence over the setting in the auditpls.ini file. AeXCustInv Executable For more information on the Custom Inventory agent, see “Custom Inventory Agent” on page 69. AeXCustInv [/?] [/d VariableName=VariableValue] [/debug] [/delfile] [/sfdir] [/sfmsecs milliseconds] [/o NSI File Full Path] [/out NSI File Name] [/in in File Path] [/indir directory] AeXCustInv Parameters Parameter Description ? Shows a usage dialog. d VariableName=VariableValue User defined variable. This parameter lets you specify the value of a variable defined within the input file. For example, if you created an input file that had a variable defined within it called %MyVar%, you could specify a value for %MyVar% by assigning MyVar a value on the command line: AeXCustInv.exe /d MyVar=Altiris Note: Do not specify the ‘%’ symbols on the command line variable name. When this parameter is used, AeXCustInv will resolve all occurrences of %MyVar% within the input file to the variable value specified on the command line. Example: Before: manufacturer='%MyVar%' After: manufacturer='Altiris' Inventory Solution for Windows Reference 96 Appendix B: Program Command Line Arguments AeXCustInv Parameters Parameter Description debug Runs AeXCustInv in DEBUG mode. This option displays detailed debugging information and reports it as AeXCustInv is running. If any errors occur during the AeXCustInv run, a message box will appear detailing the error, along with the filename and line number where the error occurred. The error will also be written to the error log. delfile Deletes the input file when finished processing. This instructs AeXCustInv to delete the input file after it has been successfully processed. If the input file is not successfully processed it will not be deleted. sfdir Startfile directory. This designates the name of the directory to write the results of a STARTFILE statement block from the input. The STARTFILE block represents a block of input beginning with <%startfile and ending with <%endfile%>. All input between these keywords will be written to a separate file to this directory. The default is the normal inventory output directory. sfmsecs milliseconds Startfile delay milliseconds. This is the number of milliseconds to delay before writing the file containing the STARTFILE block. o NSI File Full Path The optional parameter specifying the full path to the input and output XML files. If this parameter is not specified, the directory where the utility is located is used. out NSI File Name The optional parameter for specifying the output XML file name. If this parameter is not specified, a default file name is used. in in File Path The optional parameter specifying the input XML file name. If this parameter is not specified, a default file name is used. indir directory Specifies the “container” directory where multiple input XML files are located based on the current executable platform (9x, NT, etc.). When used, AeXCustInv will determine the current platform, then scan a specific subdirectory of the parent for all XML files and process them. directory is a parent directory containing one or more subdirectories of a specific name: • “Win9x” • “WinNT” • “Win2K” • “WinXP” Example: 1. You are running AeXCustInv on Win2K and have a number of XML files to be processed: file1.xml, file2.xml and file3.xml. 2. You place these XML files in a directory called c:\CustInvFiles\Win2K. 3. You run AeXCustInv with the following command line: AeXCustInv /indir c:\CustInvFiles 4. AeXCustInv determines that it is running on Win2K. It then processes all files in c:\CustInvFiles\Win2K\*.xml. 5. The output goes to the standard inventory output directory as file1.nsi, file2.nsi, file3.nsi. AeXExchPls Executable For more information on the Exchange agent, see “Exchange Agent Administration” on page 83. AeXExchPls [/?] [/hidden] [/dd] [/log] [/output format] [/o path] Inventory Solution for Windows Reference 97 Appendix B: Program Command Line Arguments AeXExchPls Parameters Parameter Description ? Shows a usage dialog. hidden If this argument is set, Exchange agent makes the progress dialog invisible. End users will not be able to cancel the scan unless they kill the process with Task Manager. This is the argument that is usually used when running the agent as it ensures that it will run on the computer without the user canceling the scan. dd If this argument is set, there is a delayed dismiss. This only works in non-hidden mode, and causes a message box to be opened at the end of the run so that the user has an indefinite period to examine data. Without the /dd argument, the user has 4 seconds after the beep (after the run) to examine data, then the window automatically closes. log If this argument is set, Exchange agent generates a trace log for any errors encountered in the current executable directory that can be used for troubleshooting and support purposes. This log file is placed in the Notification Server\Logs directory. output format The possible values are XML, MIF, or both. These settings override settings defined in the AeXExchPls.ini file. XML output data is used for real time viewing of the results. XML format is also used to load the data into Notification Server. MIF output is used by SMS. An SMS client must be configured on the computer for MIF output to be generated. o path The directory where XML output data should be generated. This setting is ignored if the output is configured for MIF only. By default, the AeXExchPls.nsi file is created in the TEMP directory on the local computer. AeXInvSoln Executable For more information on AeXInvSoln, see “Running Inventory Solution without the Altiris Agent” on page 21. AeXInvSoln [/?] [/s Configuration File] [/o Output Path] [Flags] AeXInvSoln Parameters Parameter Description ? Shows a usage dialog. s Configuration File The batch commands or INI file path. Note: These files can include # or REM to signify a commented line. For example: #This is a commented line REM So is this AeXMachInv.exe REM The above will run Inventory Solution for Windows Reference 98 Appendix B: Program Command Line Arguments AeXInvSoln Parameters Parameter Description o Output Path If this switch is used, the following happens: - the output path is created (if it does not exist) for the other agents to use - if the /cleanbeforerun or /cleanafterrun flags are included, then the output path is created. If the output path already exists and has files in it, those files are deleted. The other agents can then use this directory. Flags Additional runtime parameters: • /hidden - run in silent mode. No prompting on errors or completion. Runs invisible to the end user. • /prompt - Dialog remains open after completion. • /forcenoprompt - Closes after completion (regardless of errors). If this is not used, the window will stay open if there are errors, and close if there are no errors. • /cleanbeforerun - Cleans the install path\Altiris\Inventory folder before running. This forces completely new NSI files to be reported because there is no previous history for AeXNSInvCollector.exe to compare against. • /cleanafterrun - Deletes all NSI files and removes the install path\Altiris\Inventory folder after running. • /nocancel - No cancel button access. The end user can view the window, but cannot close it. AeXMachInv Executable For more information on the Machine Inventory agent, see “Machine Inventory Agent” on page 86. AeXMachInv [/?] [/o NSI File Full Path] [/outfilename NSI File Name] [/ini ini File Path] [/inc] [/norbin] [/zfp] AeXMachInv Parameters Parameter Description ? Shows a usage dialog. o NSI File Full Path The NSI file output path. Specifies the directory to write the files to. If this argument also includes a file, then only a single file will be written to the output path. outfilename NSI File Name The name of the NSI file to be generated. Specifies a specific file to be written to, relative to the default output directory (hence no multi file output). If neither the /o or the /outfilename arguments are used, then AeXMachInv will generate multiple files in the default output directory. ini ini File Path The full path including filename of MachInv INI file. This is used to specify those groups included or excluded from the AexMachInv run. The default is to exclude named groups but see the /inc parameter below. inc Include groups named in the MachInv INI file and exclude all others. The default is to exclude. norbin Will not include the recycle bin when scanning the hard drive for disk space used. zfp Zero footprint mode. No registry entries will be created by this run. These registry entries track IP, disk, and memory changes. AeXNSInvCollector Executable For more information on Inventory Collector, see “Customizing Data Reported by Inventory Solution” on page 27. Inventory Solution for Windows Reference 99 Appendix B: Program Command Line Arguments AeXNSInvCollector [/?] [/s SourceDir] { [/o DestDir] [/NSCTRANSPORT] [/v Server] [/url “URL”] [/mapi “Recipient”] [/mapiprofile “Profile”] [/mapiprompt] } [/a Alias] [/floppy FloppyDir] [/UseGUID] [/interval seconds] [/outGuid GUID] [/retry times] [Flags] AeXNSInvCollector Parameters Parameter Description ? Shows a usage dialog. s SourceDir The source directory for the inventory files. The default is Program Files\Altiris\express\Inventory. o DestDir The destination directory for the NSE file. The default is Program Files\Altiris\express\Outbox. NSCTRANSPORT Specifies that the Client Transport is used to relay inventory events to the server specified by the /v argument. v Server Specifies the Server name of the destination directory for the Notification Server remote event file. url “URL” Specifies the URL for the NS remote event file to be posted to. The URL must be doublequoted. If Inventory Collector cannot resolve the URL “http://ServerName.altiris.com/Altiris/NS/ postevent.asp”, it backs off to “http://ServerName/Altiris/NS/postevent.asp”, where ServerName is the name of the Notification Server. The /interval argument lets you tell how long to wait if loading postevent.asp fails. The /retry argument lets you tell how many times to retry if loading postevent.asp fails. mapi “Recipient” Specifies the recipient that the NSE attachment will be sent to using MAPI. The recipient must put the NSE attachment into the Event Outbox in order to use it. Example: aexnsinvcollector /mapi “user@altiris.com” mapiprofile “Profile” Specifies the profile used to send the NSE attachment using MAPI. This is useful if all users use the same profile name. Example: aexnsinvcollector /mapiprofile “MS Exchange Settings” mapiprompt If the user is not logged onto e-mail, and the /mapi or /mapiprofile arguments are used, /mapiprompt allows the e-mail logon prompt screen to appear. This is only needed if the e-mail program does not log on automatically. If /mapiprompt is not used with /mapi or /mapiprofile and the e-mail program does not log on automatically, /mapi and /mapiprofile will not be able to send the NSE attachment. a Alias The alias for the scenario. The default is “AltirisWin32Inventory”. floppy FloppyDir The destination directory of the Notification Server remote event file in Floppy-mode. The default is A:\. UseGUID If set, the machine GUID is sent up as the machine identifier. If there is no machine GUID available, the machine identity (name and domain) is sent up. If this parameter is not used, the machine identity gets sent up as the machine identifier instead of the machine GUID. Inventory Solution for Windows Reference 100 Appendix B: Program Command Line Arguments AeXNSInvCollector Parameters Parameter Description interval seconds This affects the URL argument (postevent.asp). The URL argument tries loading postevent.asp. If it fails, it retries in seconds. The default is 1. /outGuid GUID This causes a GUID to be generated which is used as the name of the NSE. This argument was created because the NSE names on one computer could not be guaranteed to be unique from NSE names generated on other computers. NSE names are unique in the directory they are created in on a particular computer. However, in large environments, these NSE names can be duplicated. /retry times This affects the URL argument (postevent.asp). The URL argument tries loading postevent.asp. If it fails, it retries this many times. The default is 3. Flags Additional runtime parameters: • /hidden - run in silent mode. No prompting on errors or completion. • /noprompt - closes after completion (if no errors). • /forcenoprompt - closes after completion (regardless of errors). • /nocheck - processes all files, regardless of whether they have changed since the last run. • /zfp - zero footprint mode. Example: AeXNSInvCollector /url “http://myserver/Altiris/NS/postevent.asp” /hidden /zfp AeXRunControl Executable AeXRunControl supports two modes of operation. The first is used to specify an interval to run CommandLine and to maintain it. The second mode is used to generate a random day to execute AeXRunControl. If you want to only have a program execute once a month or once a week, then AeXRunControl can be used to randomly generate this day. The first time AeXRunControl is used in Mode 2, it will generate a day of the Week or Month from the interval given at the command line (RangeMin and RangeMax). Every consequent execution of AexRunControl will check to see if the mode (WEEKLY/MONTHLY) or range has changed. If not, it will only execute CommandLine if the last execution was before the scheduled time, and the current time is after the scheduled time. Should any of the command line arguments to AeXRunControl change, a new scheduled day will be generated. Usage: Mode 1 AeXRunControl [Key] [Number of Hours] [CommandLine] [ [/useHKCU]|[/d:#min-#max] ] Mode 2 AeXRunControl [/rndschedule] [Key] [CommandLine] [WEEKLY|MONTHLY] [RangeMin] [RangeMax] [ Inventory Solution for Windows Reference 101 Appendix B: Program Command Line Arguments [/useHKCU]|[/d:#min-#max]|[/now] ] AeXRunControl Parameters Parameter Description Key ID Name for the command you are controlling and is used as a registry key to store when it was last run (for example: “Inventory Solution”). Number of Hours Number of hours between running (for example: 48 = 2 days). CommandLine The command to execute (for example: “\\NS\nscap\bin\win32\x86\AeXInvSoln.exe”). The CommandLine argument must be surrounded by parentheses if you pass parameters. WEEKLY|MONTHLY The string WEEKLY or MONTHLY to denote the time period of the schedule. (This is not case sensitive – “weekly” or “Weekly” are valid). RangeMin and RangeMax The lower and upper bounds for the randomly generated day of the week/month (restricted to 1-7 and 1-31 respectively). Weekdays are: 1 = Sunday, 2 = Monday, etc. useHKCU Normally, the registry entries are written to HKey Local Machine (HKLM), but the user may not have Admin rights to write to this location. In this case, this argument will cause it to be written to HKey Current User (HKCU). d:#min-#max This argument will generate a delay each time the CommandLine program is run. When this argument is used, AeXRunControl will wait for a time between #min and #max (the delay is in seconds) before actually executing the CommandLine. rndschedule Signifies the use of the format (Mode 2) that supports the randomized schedule. now If this is the first time that the CommandLine program is run, this argument will cause the program to execute, as well as generate a scheduled day for it to execute next time. Normally, the first time AeXRunControl is used, it will generate the scheduled day, and only run if the current day is on or after that day. The now argument can only be used with the rndschedule argument. AeXSNPlus Executable For more information on the Serial Number agent, see “Serial Number Agent Administration” on page 85. AeXSNPlus [/?] [/AllowChars ccc] [/visible] [/dd] [/datapath path] [/output format] [/o path] [/ini filename] [/ChkModel] [/ToSecs x] [/AToSecs x] [/DelaySeconds x] [/ForceSN field] [/ErrPath path] [/InfPath path] [/MIFPath path] [/CENames] [/LogPath path] [/NoSNData16] [/NoWbem] [/NoWebmifSNFound] Inventory Solution for Windows Reference 102 Appendix B: Program Command Line Arguments AeXSNPlus Parameters Parameter Description ? Shows a usage dialog. AllowChars ccc A serial number will typically include only letters, numbers, space, or dash. All other characters are ignored. By specifying characters represented by ccc, you can include support for additional characters. Example: /AllowChars +, will cause AexSNPlus to also consider '+' and ',' as valid characters. visible Shows the status during execution. dd Delayed dismiss. This only works in non-hidden mode and causes a message box to be opened at the end of the run. The user has an indefinite period to examine data. Without the /dd argument, the user has 4 seconds after the beep (after the run) to examine data, then the window automatically closes. datapath path The directory for the Serial Number agent to place all SNPlus and SNData output. This excludes XML and MIF output. Use /O for XML output. output format The possible values are XML, MIF, or both. XML output data is used for real time viewing of the results. XML format is also used to load the data into Notification Server. MIF output is used by SMS. An SMS client must be configured on the computer for MIF output to be generated. o path If this argument is set, the Serial Number agent places the output XML in path. ini filename This contains the full path and filename of the INI file for the Serial Number agent to use. ChkModel If this argument is set, the Serial Number agent inspects and replaces a bad computer model with a good computer model and vice versa. ToSecs x If this argument is set, <x> contains the number of seconds to allow each internal SNData.exe to run. The default is 5. This excludes the last run. Use /AToSecs x to apply to the last run as well. Note: The minimum value for this argument is 5. Any number under 5 is ignored. AToSecs x If this argument is set, x contains the number of seconds to allow each internal SNData.exe to run, including the last run. The default is 5. Note: The minimum value for this argument is 5. Any number under 5 is ignored. DelaySeconds x If this argument is set, x contains the number of seconds after computer startup to wait before executing. The default is 300 seconds (5 minutes). ForceSN field If this argument is set, field is the alternate computer field to use as the serial number, regardless of the presence of other fields. The allowable values are asset, baseboard, and enclosure. The field will still be validated. ErrPath path If this argument is set, path is the directory for the Serial Number agent to write diagnostic files when the serial number is not detected. This can contain a relative path specifier. InfPath path If this argument is set, path is the directory for the Serial Number agent to write diagnostic files regardless of whether or not there was an error. This can contain a relative path specifier. MIFPath path If this argument is set, path is the directory for the Serial Number agent to write a copy of the MIF file produced. This can contain a relative path specifier. NoSNData16 The argument tells AexSNPlus to not run its 16 bit version if the 32 bit version fails while gathering serial number information. NoWbem Instructs AexSNPlus not to execute its internal Wbem client as part of its serial number retrieval process. This option is used for those rare cases where the execution of the Wbem client crashes on the computer. NoWebmifSNFound Will not launch the Wbem client program if AexSNPlus was able to successfully obtain a valid serial number. Inventory Solution for Windows Reference 103 Appendix B: Program Command Line Arguments AeXSNPlus Parameters Parameter Description CENames Results in AeXSNPlus writing its output MIFs using the same old group NAME and CLASS names that were in place prior to release 5.1. This way, existing AeXSNPlus customers can continue to run the program with no SMS table name changes and no loss of history. If you are upgrading from a previous version of AeXSNPlus, and you don’t use the CENames argument, the names will change in the following manner: the references to “CE . . .” will be replaced with “AeX . . .” and “ComputingEdge . . .” will be replaced with “Altiris . . ..” For Example: OLD: Name=“CE HW Memory Modules” Class= “ComputingEdge|MemMod|2.0” NEW: Name=“AeX HW Memory Modules” Class= “Altiris|MemMod|2.0” SMS will drop the old table names and thus the history associated with these tables. If you are upgrading and don’t want to lose this information, use the CENames argument. LogPath path Lets you specify an override to the output path used for logging (default is c:\). AeXSNPlus checks the target directory before writing the log file (snplus.log). If it is unavailable, it tries using the TMP directory. If that is unavailable, no logging occurs. Inventory Solution for Windows Reference 104 Appendix C: Inventory Solution Data Reference The following table displays a list of inventory tables that are found in the Notification Server database. Table Name Description AeX AC Client Agent Provides information about any Altiris Agents installed on the target computer. AeX AC Client Connectivity Provides information about Altiris Agent connectivity. AeX AC Identification Provides summary level inventory information about the target computer (OS, User info, etc). AeX AC Inventory Results Contains information about the last inventory scan. AeX AC Location Contains Domain distinguished name information. AeX AC Machine Usage Contains computer usage information. AeX AC NT Services Contains information on NT services installed on the target computer. AeX AC Primary User Contains information about the Primary User of a target computer for a given interval. AeX AC Resource Inventory Summary Contains summary information on resource inventory. AeX AC Roles Determines role of target computer based on installed software and services. AeX AC SMS Client Properties Contains information regarding SMS Client settings. AeX AC TCPIP Contains detailed TCPIP information, settings, and configuration data for target computers. AeX DB ODBC Drivers Contains ODBC driver information. AeX DB MDAC Contains MDAC information. AeX DB SQL Server Contains SQL server information. AeX AX Discovery Contains discovery information. AeX EU Contact Detail Contains location and contact information for Exchange User accounts discovered on the target computer. AeX EU Logon Users Contains information regarding logon user activity on target computers. AeX EU Mail Profiles Contains the installed e-mail profiles for target computers. AeX EU Results Contains information regarding the last user inventory scan. AeX HW ActiveTcpUdpPorts Contains information on active TCP and UDP ports. AeX HW BIOS Contains BIOS details for target computers. AeX HW CPU Contains CPU information for target computers. Inventory Solution for Windows Reference 105 Appendix C: Inventory Solution Data Reference AeX HW Disk Space Usage Contains information on how much space TMP and recycle bin files are consuming on the target computer. AeX HW Logical Disk Contains information about the logical drive partitions on the target computer. AeX HW Logical Disk Changes Tracks changes to the logical drive partitions on the target computer. AeX HW Memory Contains total physical memory and page file size on the target computer. AeX HW Memory Changes Tracks changes to the total physical memory and page file on the target computer. AeX HW Memory Modules Contains information about installed RAM modules on the target computer. AeX HW Modems Contains information on installed modems on the target computer. AeX HW Monitor Contains information on the monitor(s) attached to the target computer. AeX HW Mouse Contains information about installed mouse devices on the target computer AeX HW Network Cards Contains information regarding installed network adapters on the target computer. AeX HW PCI Bus Contains information regarding devices using the PCI bus on the target computer. AeX HW PCMCIA Devices Contains information on installed PCMCIA devices on the target computer. AeX HW Physical Disk Contains information on installed physical disk drives on the target computer (NT/2000/XP). AeX HW Printer Contains information on installed printers on the target computer, network and local. AeX HW SCSI Contains information on installed SCSI devices on the target computer. AeX HW Serial Number Contains serial number, manufacturer, and asset tag information for the target computer. AeX HW SMBIOS Contains information about SMBIOS and DMI abilities on the target computer. AeX HW Video Contains information on installed video adapters and drivers on the target computer. AeX HW Video Monitor Contains information on installed display devices on the target computer. AeX OS ACLs Contains Access Control List information on the target computer. AeX OS Add Remove Programs Contains information on software packages registered by the Windows installer on the target computer. AeX OS Admin Group Contains information on membership in the local admin group for the target computer. AeX OS AT Scheduler Contains information on the AT command list. AeX OS Audit Policy Contains information on the audit settings on the target computer. AeX OS Desktop Contains information about the target computer Desktop settings. AeX OS IIS Contains information on target computers which have IIS installed. AeX OS Internet Explorer Contains IE configuration and version settings for the target computer. AeX OS Memory Management Contains information and settings for paging files for the target computer. AeX OS Network Provider Contains information on installed network providers on the target computer. Inventory Solution for Windows Reference 106 Appendix C: Inventory Solution Data Reference AeX OS Network Shares Contains information on shared directories/files on the target computer. AeX OS Operating System Contains version and installation information for the OS on the target computer. AeX OS Provider Order Contains information on the order for installed network providers on the target computer. AeX OS Quick Fix Engineering Contains information on installed OS updates for Win 9x computers with WMI installed. AeX OS RAS Server Contains configuration information for target computers hosting RAS services. AeX OS Results Contains information on installed script hosting engines on the target computer. AeX OS System Contains basic Domain and User information for current logged on user when inventory was performed on the target computer. AeX OS System Devices Contains information on installed system devices that appear in Device Manager on the target computer. AeX OS Task Scheduler Contains information on tasks scheduled via the Windows Task Scheduler on the target computer. AeX OS TCPIP Changes Tracks changes to TCPIP information on the target computer. AeX OS Time Zone Contains information on the Time Zone settings on the target computer. AeX OS Updates Contains information on installed OS updates on the target computer (NT/2000/XP). AeX OS User Profiles Contains information about installed local accounts on the target computer. AeX OS Win16 Subsystem Contains information on the Win16 subsystem configuration on the target computer. AeX OS Windows 9x Contains OS installation information specific to Windows 9x computers. AeX OS Windows NT Contains OS information and settings specific to Windows NT/2000/XP computers. AeX SW Audit Results Contains summary information on the last software inventory performed on the target computer. AeX SW Audit Software Contains detailed file information for installed applications on the target computer. AeX SW [Special Group] Contains file details based on a special group definition. AeX USB Bus Contains USB bus information. AeX VirtualMachine Contains virtual machine information. Inventory Solution for Windows Reference 107 Index A Advanced tab 57 advertisement creating 40 status 41 AeXAuditpls 19, 25, 27, 95, 96, 97, 98, 99, 101, 102 AeXCustInv 19, 69, 96 AeXExchPls 97 AeXExchpls 25, 27 AeXInvSoln 98 AeXInvSoln.exe 27 AeXInvSoln.ini 42 AeXMachInv 19, 27, 99 AeXNSInvCollector 19, 25, 27, 99 aexnsinvcollector 28 AeXRunControl 101 AeXSNPlus 19, 25, 27, 102 AeXWebInvPkg.exe 30 agent 27 Agent deployment 35 Altiris Agent 20 deployment 35 Application Management 59 Audit agent 49 benefits 49 configuration 50, 54 customization 50 files 51 finding one file 67 how it works 52 input 50 logon scripts 51 removing data from SMS 41 scanning for data 66 troubleshooting 66 using with login script 66 auditpls.ini 50 B Baseline 59 BIOS 8 C checking package status 40 clean after run mode 23 clean before run mode 23 collecting data through SMS 36 collection verifying target 40 command line argument 25 comparing files 24 compatibility operating systems 11 SMS 9 configuration editor 56 copyright 2 creation date of document 2 D data customizing 27 posting 29 data class create for special group 65 data collection through SMS 36 data flow 46 data output format 25 data reference 105 deploying a package 39 deployment 9 Directories tab 58 document print date 2 E e-mail 29, 34 using to run Inventory Solution 23 e-mail attachment 44 e-mail distribution 19 Exchange agent 82 administration 83 configuration 82 data reported to SMS 82 how it works 82 troubleshooting 84 Exclusion Filters Tab 59 F file required 36 searching for 55 file access from network 34 file compare 24 File Masks Tab 61 floppy disk creating 34 floppy disk based Inventory Solution 8, 34 format of data output 25 frequency of scan 35 Inventory Solution for Windows Reference H HTTP posting 44 I input command line argument 25 integrating with SMS 9 introduction 7 inventory 105 Inventory Collector 28 inventory posting 35 inventory results 26 inventory scan 35 Inventory Solution agent 27 data flow 46 running 19 running from e-mail 23 running from Web page 23 with Altiris Agent 20 inventory table reference 105 K Known As Tab 61 L legal notice 2 log 45 logon script 21 logon script agent deployment 35 M managing patches 29 Manufacturer Known As Tab 62 MIF output 36 N NetWare 14, 28, 34 network file access 34 NOIDMIF directory 84, 85 NOIDMIFS folder 25 notice 2 Notification Server Event file 27 NSE file 27 NSI file 24 O OS updates 29 output command line argument 25 output data format 25 Overrides Tab 62 108 Index overview 7 P package creation for SMS 37 package definition file 36 package deployment 39 package status checking 40 patches managing 29 patent 2 PC serial number 8 PDF 36 port 44 posting data 29 posting inventory data 35 product version 2 R removing Audit agent data 41 report 29 reporting customizing data 27 required files 36 running Inventory Solution 19 S scan frequency 35 searching for files 55 security 25 serial number 8 Serial Number agent 85 administration 85 troubleshooting 85 SMS collection of data 36 compatibility 9 integration 9 package creation 37 Software Audit agent 49 Special Groups tab 63 status of advertisement 41 status of package 40 T target collection 40 timeout 45 trademark 2 U UNIX 14, 28, 30, 34 updates 29 using a floppy disk 34 V version 2 W web inventory package 14, 30 Web page 23 Win32 API 27 Z zero footprint mode 19, 34 Inventory Solution for Windows Reference 109