Solved

How do I install printer and add additional tray under install options using VBS?

Posted on 2008-10-22
2
718 Views
Last Modified: 2012-05-05
My company is getting a new model of Multi-Function-Printers: Lexmark X646e.  I am having to install them on multiple floors for hundreds of people.  I have a VBS install script that installs the printer and uses the latest driver.  There is one problem.  The print driver install does not automatically sense the additional 500 sheet trays Installed with the printer.

You can manually add the additional tray on each PC via the "Install Options" tab under printer properties, but I would like to have this done automatically through the script.

These are Windows XP Pro clients, SP2.  I have attached my current code.  

Any Ideas?
'Option Explicit
On Error Resume Next
Set objNetwork = CreateObject("WScript.Network")
Set objShell = CreateObject("WScript.Shell")
 
'**************************************
'* Define Constants & Global Variables
'**************************************
Dim objDomainUser, objNetwork, objShell, strComputer, colDrives, i
Dim objWMI, objNewPort, strPrinterHost, strPrinterName, strPrinterDriver, strUserName, strPrinterDriverLocation, strPrinterDriverInfFile
 
 
 
'
 
'****Printer Lexmark646e*****************
Strcomputer ="."
Set objWMIService = GetObject("winmgmts:{impersonationLevel=impersonate}!\\.\root\cimv2")
objWMI.Security_.Privileges. _
    AddAsString "SeLoadDriverPrivilege", True
Set colInstalledPrinters = objWMIService.ExecQuery("Select * from Win32_Printer where DeviceID = 'PrinterLX'")                                                                                             
For Each objPrinter in colInstalledPrinters 
objPrinter.Delete_
Next
' Put the hostname of the printer here
strPrinterHost = "PrinterLX"
' Put the name of the printer here
strPrinterName = "PrinterLX"
Set objShell = CreateObject("WScript.Shell")
' Create the printer port
Set objWMI = GetObject("winmgmts:{impersonationLevel=impersonate}!\\.\root\cimv2")
objWMI.Security_.Privileges. _
    AddAsString "SeLoadDriverPrivilege", True
Set objNewPort = objWMI.Get("Win32_TCPIPPrinterPort").SpawnInstance_
objNewPort.Name = "IP_" & strPrinterHost
objNewPort.Protocol = 1
objNewPort.HostAddress = strPrinterHost
objNewPort.PortNumber = "9100"
objNewPort.SNMPEnabled = False
objNewPort.Put_
 
 
objshell.run "RUNDLL32 PRINTUI.DLL,PrintUIEntry /if /b ""PrinterLX""" & " /f " & """\\ServerShare\Printers\prdrivers\lexmarkx646\win_2kxp\LMABC2DA.INF""" & " /r " & """ip_PrinterLX""" & " /m " & """Lexmark X646e""",,True
 
 
'

Open in new window

0
Comment
Question by:marktgeorge
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 2
2 Comments
 

Accepted Solution

by:
marktgeorge earned 0 total points
ID: 22991271
I figured it out with the help of the lexmark provided utility that automates installs using the proprietary lexmark install software scripts.  However I will say it is much simpler to administer and change when using a blend of the two (use vbs to create printer and printer ports and use lexmark for driver customization).  You can call the lexmark utility from your vbs scripts.  However, there are some shortcomings on the switches used by lexmark's executable.  Yes, the lexmark utility also allows for remote installs on multiple pcs, but it requires hard coded username and password for install rights.  In my organization, that is not an option - perversely strict security requirements!
0
 

Author Comment

by:marktgeorge
ID: 22991328
Use the above code to create the printer object and port, then call Lexmarks install utility(in the vbs code) and Lexmark custom created answer file to install the customized driver complete with tray and other add-on options you specified.   The Lexmark software will come with the printer.

0

Featured Post

What does it mean to be "Always On"?

Is your cloud always on? With an Always On cloud you won't have to worry about downtime for maintenance or software application code updates, ensuring that your bottom line isn't affected.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Recently I finished a vbscript that I thought I'd share.  It uses a text file with a list of server names to loop through and get various status reports, then writes them all into an Excel file.  Originally it was put together for our Altiris server…
Script to copy or move mouse-selected collection of files plus targets referenced by shortcuts (.lnk) The purpose of this article is to help illuminate the real challenges and options available (where they may exist) for utilizing simple scriptin…
There's a multitude of different network monitoring solutions out there, and you're probably wondering what makes NetCrunch so special. It's completely agentless, but does let you create an agent, if you desire. It offers powerful scalability …
In this video you will find out how to export Office 365 mailboxes using the built in eDiscovery tool. Bear in mind that although this method might be useful in some cases, using PST files as Office 365 backup is troublesome in a long run (more on t…

632 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question