From 9e7500722a04447063932fdf03e7b0e4d98a7d87 Mon Sep 17 00:00:00 2001 From: John Terpstra Date: Fri, 24 Jun 2005 02:30:32 +0000 Subject: Update. (This used to be commit 25d19245013b188da7b43862a7e09b85f7ce0495) --- docs/Samba3-HOWTO/TOSHARG-Printing.xml | 1073 ++++++++++++++++++-------------- 1 file changed, 610 insertions(+), 463 deletions(-) (limited to 'docs') diff --git a/docs/Samba3-HOWTO/TOSHARG-Printing.xml b/docs/Samba3-HOWTO/TOSHARG-Printing.xml index d9c5270c76..7b82190398 100644 --- a/docs/Samba3-HOWTO/TOSHARG-Printing.xml +++ b/docs/Samba3-HOWTO/TOSHARG-Printing.xml @@ -6,7 +6,7 @@ KurtPfeifle - Danka Deutschland GmbH + Danka Deutschland GmbH
kpfeifle@danka.de
@@ -21,49 +21,57 @@ Features and Benefits -Printing is often a mission-critical service for the users. Samba can -provide this service reliably and seamlessly for a client network -consisting of Windows workstations. - - - -A Samba print service may be run on a standalone or domain member server, -side by side with file serving functions, or on a dedicated print server. -It can be made as tightly or as loosely secured as needs dictate. Configurations -may be simple or complex. Available authentication schemes are essentially -the same as described for file services in previous chapters. Overall, -Samba's printing support is now able to replace an NT or Windows 2000 -print server full-square, with additional benefits in many cases. Clients -may download and install drivers and printers through their familiar -Point'n'Print mechanism. Printer installations executed by -Logon Scripts are no problem. Administrators can upload and -manage drivers to be used by clients through the familiar Add Printer -Wizard. As an additional benefit, driver and printer management may -be run from the command line or through scripts, making it more efficient -in case of large numbers of printers. If a central accounting of print jobs -(tracking every single page and supplying the raw data for all sorts of -statistical reports) is required, this function is best supported by -the newer Common UNIX Printing System (CUPS) -as the print subsystem underneath the Samba hood. - - - -This chapter deals with the foundations of Samba printing as they -are implemented by the more traditional UNIX (BSD and System V-style) -printing systems. Much of the information in this chapter applies also to CUPS. -If you use CUPS, you may be tempted -to jump to the next chapter, but you will certainly miss a few things if -you do. It is recommended that you read this chapter as well as CUPS Printing Support. +mission-critical +Printing is often a mission-critical service for the users. Samba can provide this service reliably and +seamlessly for a client network consisting of Windows workstations. + + + +print service +domain member server +standalone server +file serving +dedicated print server +print server +printing support +Point'n'Print +Add Printer Wizard +upload drivers +manage drivers +install drivers +print accounting +Common UNIX Printing SystemCUPS +A Samba print service may be run on a standalone or domain member server, side by side with file serving +functions, or on a dedicated print server. It can be made as tightly or as loosely secured as needs dictate. +Configurations may be simple or complex. Available authentication schemes are essentially the same as +described for file services in previous chapters. Overall, Samba's printing support is now able to replace an +NT or Windows 2000 print server full-square, with additional benefits in many cases. Clients may download and +install drivers and printers through their familiar Point'n'Print mechanism. Printer +installations executed by Logon Scripts are no problem. Administrators can upload and manage +drivers to be used by clients through the familiar Add Printer Wizard. As an additional +benefit, driver and printer management may be run from the command line or through scripts, making it more +efficient in case of large numbers of printers. If a central accounting of print jobs (tracking every single +page and supplying the raw data for all sorts of statistical reports) is required, this function is best +supported by the newer Common UNIX Printing System (CUPS) as the print subsystem underneath the Samba hood. + + + +BSD +CUPS +This chapter outlines the fundamentals of Samba printing as implemented by the more traditional UNIX +BSD- and System V-style printing systems. Much of the information in this chapter applies also to CUPS. If +you use CUPS, you may be tempted to jump to the next chapter, but you will certainly miss a few things if you +do. For further information refer to CUPS Printing Support. -Most of the following examples have been verified on Windows XP -Professional clients. Where this document describes the responses to -commands given, bear in mind that Windows 200x/XP clients are quite -similar but may differ in minor details. Windows NT is somewhat different -again. +Windows XP Professional +Windows 200x/XP +Windows NT4 +Most of the following examples have been verified on Windows XP Professional clients. Where this document +describes the responses to commands given, bear in mind that Windows 200x/XP clients are quite similar but may +differ in minor details. Windows NT4 is somewhat different again. @@ -73,40 +81,49 @@ again. Technical Introduction -Samba's printing support always relies on the installed print subsystem -of the UNIX OS it runs on. Samba is a middleman. It takes -print files from Windows (or other SMB) clients and passes them to the real -printing system for further processing; therefore, it needs to communicate with -both sides: the Windows print clients and the UNIX printing system. Hence, we -must differentiate between the various client OS types, each of which behave -differently, as well as the various UNIX print subsystems, which themselves -have different features and are accessed differently. +printing support +print subsystem +printing system +Samba's printing support always relies on the installed print subsystem of the UNIX OS it runs on. Samba is a +middleman. It takes print files from Windows (or other SMB) clients and passes them to the real +printing system for further processing; therefore, it needs to communicate with both sides: the Windows print +clients and the UNIX printing system. Hence, we must differentiate between the various client OS types, each +of which behave differently, as well as the various UNIX print subsystems, which themselves have different +features and are accessed differently. -This chapter deals with the traditional way of UNIX printing. The next chapter -covers in great detail the more modern -CUPS. +UNIX printing +CUPS +This chapter deals with the traditional way of UNIX printing. The next chapter covers in great detail the more +modern CUPS. -CUPS users, be warned: do not just jump on to the next -chapter. You might miss important information only found here! + +CUPS +CUPS users, be warned: do not just jump on to the next chapter. You might miss important information only found here! -It is apparent from postings on the Samba mailing list that print configuration -is one of the most problematic aspects of Samba administration today. Many -new Samba administrators have the impression that Samba performs some sort -of print processing. Rest assured, Samba does not perform any type of print -processing. It does not do any form of print filtering. +print configuration +problematic print +print processing +print filtering +It is apparent from postings on the Samba mailing list that print configuration is one of the most problematic +aspects of Samba administration today. Many new Samba administrators have the impression that Samba performs +some sort of print processing. Rest assured, Samba does not perform any type of print processing. It does not +do any form of print filtering. -Samba obtains from its clients a data stream (print job) that it spools to a -local spool area. When the entire print job has been received, Samba invokes -a local UNIX/Linux print command and passes the spooled file to it. It is -up to the local system printing subsystems to correctly process the print -job and to submit it to the printer. +data stream +local spool area +spooled file +local system printing +Samba obtains from its clients a data stream (print job) that it spools to a local spool area. When the entire +print job has been received, Samba invokes a local UNIX/Linux print command and passes the spooled file to it. +It is up to the local system printing subsystems to correctly process the print job and to submit it to the +printer. @@ -118,24 +135,23 @@ printer involves six (potentially seven) stages: -Windows opens a connection to the printer share. + Windows opens a connection to the printer share. -Samba must authenticate the user. + Samba must authenticate the user. -Windows sends a copy of the print file over the network -into Samba's spooling area. + Windows sends a copy of the print file over the network + into Samba's spooling area. -Windows closes the connection. + Windows closes the connection. -Samba invokes the print command to hand the file over -to the UNIX print subsystem's spooling area. + Samba invokes the print command to hand the file over + to the UNIX print subsystem's spooling area. -The UNIX print subsystem processes the print job. - -The print file may need to be explicitly deleted -from the Samba spooling area. This item depends on your print spooler -configuration settings. + The UNIX print subsystem processes the print job. + The print file may need to be explicitly deleted + from the Samba spooling area. This item depends on your print spooler + configuration settings. @@ -143,11 +159,12 @@ configuration settings. Printing-Related Configuration Parameters -There are a number of configuration parameters to control Samba's -printing behavior. Please refer to the man page for &smb.conf; for an -overview of these. As with other parameters, there are global-level -(tagged with a G in the listings) and service-level -(S) parameters. +global-level +service-level +printing behavior +There are a number of configuration parameters to control Samba's printing behavior. Please refer to the man +page for &smb.conf; for an overview of these. As with other parameters, there are global-level (tagged with a +G in the listings) and service-level (S) parameters. @@ -177,13 +194,15 @@ overview of these. As with other parameters, there are global-level Simple Print Configuration -Example 20.3.1 shows a simple printing configuration. -If you compare this with your own, you may find -additional parameters that have been preconfigured by your OS -vendor. Following is a discussion and explanation of the -parameters. This example does not use many parameters. -However, in many environments these are enough to provide a valid -&smb.conf; file that enables all clients to print. +BSD Printing +simple printing +enables clients to print +print environment +Simple Configuration with BSD Printing shows a simple printing configuration. +If you compare this with your own, you may find additional parameters that have been preconfigured by your OS +vendor. Following is a discussion and explanation of the parameters. This example does not use many +parameters. However, in many environments these are enough to provide a valid &smb.conf; file that enables +all clients to print. @@ -202,49 +221,58 @@ However, in many environments these are enough to provide a valid -This is only an example configuration. Samba assigns default values to -all configuration parameters. The defaults are conservative -and sensible. When a parameter is specified in the &smb.conf; file, this -overwrites the default value. The testparm utility when -run as root is capable of reporting all settings, both default as well as -&smb.conf; file settings. Testparm gives warnings for all -misconfigured settings. The complete output is easily 340 lines and more, -so you may want to pipe it through a pager program. +testparm +misconfigured settings +pager program +This is only an example configuration. Samba assigns default values to all configuration parameters. The +defaults are conservative and sensible. When a parameter is specified in the &smb.conf; file, this overwrites +the default value. The testparm utility when run as root is capable of reporting all +settings, both default as well as &smb.conf; file settings. Testparm gives warnings for all +misconfigured settings. The complete output is easily 360 lines and more, so you may want to pipe it through a +pager program. - -The syntax for the configuration file is easy to grasp. You should -know that is not very picky about its syntax. As has been explained -elsewhere in this book, Samba tolerates some spelling errors (such -as instead of -), and spelling is -case-insensitive. It is permissible to use Yes/No -or True/False for Boolean settings. Lists of names -may be separated by commas, spaces, or tabs. + +configuration syntax +syntax tolerates spelling errors +case-insensitive +The syntax for the configuration file is easy to grasp. You should know that is not very picky about its +syntax. As has been explained elsewhere in this book, Samba tolerates some spelling errors (such as + instead of ), and spelling is +case-insensitive. It is permissible to use Yes/No or True/False +for Boolean settings. Lists of names may be separated by commas, spaces, or tabs. Verifying Configuration with <command>testparm</command> -To see all (or at least most) printing-related settings in Samba, including -the implicitly used ones, try the command outlined below. This command greps -for all occurrences of lp, print, spool, driver, ports, -and [ in testparm's output. This provides a convenient -overview of the running smbd print configuration. This -command does not show individually created printer shares or the spooling -paths they may use. Here is the output of my Samba setup, with settings -shown in the example above: - - - +printing-related settings +lp +print +spool +driver +ports +testparm +smbd +print configuration +printer shares +spooling path +To see all (or at least most) printing-related settings in Samba, including the implicitly used ones, try the +command outlined below. This command greps for all occurrences of lp, +print, spool, driver, +ports, and [ in testparm's output. This provides +a convenient overview of the running smbd print configuration. This command does not show +individually created printer shares or the spooling paths they may use. Here is the output of my Samba setup, +with settings shown in the example above: + &rootprompt;testparm -s -v | egrep "(lp|print|spool|driver|ports|\[)" Load smb config files from /etc/samba/smb.conf Processing section "[homes]" Processing section "[printers]" [global] - smb ports = 445 139 + smb ports = 139 445 lpq cache time = 10 load printers = Yes printcap name = /etc/printcap @@ -281,22 +309,26 @@ default behavior. Remember: it may be important in your future dealings with Samba. - testparm in Samba-3 behaves differently from that in 2.2.x: used -without the -v switch, it only shows you the settings actually -written into! To see the complete -configuration used, add the -v parameter to testparm. + +The testparm in Samba-3 behaves differently from that in 2.2.x: used without the +-v switch, it only shows you the settings actually written into! To see the complete +configuration used, add the -v parameter to testparm. + Rapid Configuration Validation - -Should you need to troubleshoot at any stage, please always come back -to this point first and verify if testparm shows the parameters you -expect. To give you a warning from personal experience, -try to just comment out the -parameter. If your 2.2.x system behaves like mine, you'll see this: + +troubleshoot +testparm +parameters +verify +Should you need to troubleshoot at any stage, please always come back to this point first and verify if +testparm shows the parameters you expect. To give you a warning from personal experience, +try to just comment out the parameter. If your 2.2.x system behaves like +mine, you'll see this: @@ -309,12 +341,12 @@ parameter. If your 2.2.x system behaves like mine, you'll see this: +commenting out setting +publishing printers I assumed that commenting out of this setting should prevent Samba from publishing my printers, but it still did. It took some time to figure out the reason. But I am no longer fooled ... at least not by this. - - - + &rootprompt;grep -A1 "load printers" /etc/samba/smb.conf load printers = No # The above setting is what I want! @@ -323,24 +355,22 @@ the reason. But I am no longer fooled ... at least not by this. &rootprompt;testparm -s -v smb.conf.simpleprinting | egrep "(load printers)" load printers = No - -Only when the parameter is explicitly set to -No -would Samba conform with my intentions. So, my strong advice is: +explicitly set +Only when the parameter is explicitly set to No would +Samba conform with my intentions. So, my strong advice is: -Never rely on commented-out parameters. - -Always set parameters explicitly as you intend them to -behave. + Never rely on commented-out parameters. -Use testparm to uncover hidden -settings that might not reflect your intentions. + Always set parameters explicitly as you intend them to + behave. + Use testparm to uncover hidden + settings that might not reflect your intentions. @@ -351,19 +381,16 @@ The following is the most minimal configuration file: -This example should show that you can use testparm to test any Samba -configuration file. Actually, we encourage you not -to change your working system (unless you know exactly what you are -doing). Don't rely on the assumption that changes will only take effect after -you restart smbd! This is not the case. Samba rereads it every 60 seconds -and on each new client connection. You might have to face changes for your -production clients that you didn't intend to apply. You will now -note a few more interesting things; testparm is useful to -identify what the Samba print configuration would be if you used this minimalistic -configuration. Here is what you can expect to find: - - - +testparm +smbd +This example should show that you can use testparm to test any Samba configuration file. +Actually, we encourage you not to change your working system (unless you know exactly +what you are doing). Don't rely on the assumption that changes will only take effect after you restart smbd! +This is not the case. Samba rereads it every 60 seconds and on each new client connection. You might have to +face changes for your production clients that you didn't intend to apply. You will now note a few more +interesting things; testparm is useful to identify what the Samba print configuration would +be if you used this minimalistic configuration. Here is what you can expect to find: + &rootprompt;testparm -v smb.conf-minimal | egrep "(print|lpq|spool|driver|ports|[)" Processing section "[printers]" WARNING: [printers] service MUST be printable! @@ -390,7 +417,6 @@ configuration. Here is what you can expect to find: [printers] printable = Yes - @@ -403,48 +429,48 @@ configuration. Here is what you can expect to find: -However, this was not fatal, and Samba will default to values that will -work. Please, do not rely on this and do not use this example. This was -included to encourage you to be careful to design and specify your setup to do -precisely what you require. The outcome on your system may vary for some -parameters given, since Samba may have been built with different compile-time -options. Warning: do not put a comment sign -at the end of a valid line. It will cause the parameter -to be ignored (just as if you had put the comment sign at the front). At first -I regarded this as a bug in my Samba versions. But the man page clearly says: -Internal whitespace in a parameter value is retained verbatim. -This means that a line consisting of, for example, - - - +compile-time options + + + +However, this was not fatal, and Samba will default to values that will work. Please, do not rely on this and +do not use this example. This was included to encourage you to be careful to design and specify your setup to +do precisely what you require. The outcome on your system may vary for some parameters given, since Samba may +have been built with different compile-time options. Warning: do not put a comment sign +at the end of a valid line. It will cause the parameter to be ignored (just as if you had +put the comment sign at the front). At first I regarded this as a bug in my Samba versions. But the man page +clearly says: Internal whitespace in a parameter value is retained verbatim. This means +that a line consisting of, for example, + This defines LPRng as the printing system lprng - + + -will regard the whole of the string after the -= sign as the value you want to -define. This is an invalid value that will be ignored, and a default -value will be -used in its place. +will regard the whole of the string after the = sign as the value you want to define. This +is an invalid value that will be ignored, and a default value will be used in its place. + + Extended Printing Configuration -Example 20.4.1 shows a more verbose configuration -for print-related settings in a BSD-style printing environment. What follows -is a discussion and explanation of the various parameters. We chose to -use BSD-style printing here because it is still the most commonly used -system on legacy UNIX/Linux installations. New installations predominantly -use CUPS, which is discussed in a separate chapter. The example explicitly -names many parameters that do not need to be specified because they are set -by default. You could use a much leaner &smb.conf; file, or you can use -testparm or SWAT to optimize the &smb.conf; -file to remove all parameters that are set at default. +Extended BSD Printing +BSD-style printing +CUPS +testparm +Extended BSD Printing Configuration shows a more verbose configuration for +print-related settings in a BSD-style printing environment. What follows is a discussion and explanation of +the various parameters. We chose to use BSD-style printing here because it is still the most commonly used +system on legacy UNIX/Linux installations. New installations predominantly use CUPS, which is discussed in a +separate chapter. The example explicitly names many parameters that do not need to be specified because they +are set by default. You could use a much leaner &smb.conf; file, or you can use testparm or +SWAT to optimize the &smb.conf; file to remove all parameters that are set at default. @@ -483,122 +509,152 @@ file to remove all parameters that are set at default. -This is an example configuration. You may not find all the settings that are in -the configuration file that was provided by the OS vendor. Samba configuration -parameters, if not explicitly set, default to a sensible value. -To see all settings, as root use the testparm -utility. testparm gives warnings for misconfigured settings. + + + +This is an example configuration. You may not find all the settings that are in the configuration file that +was provided by the OS vendor. Samba configuration parameters, if not explicitly set, default to a sensible +value. To see all settings, as root use the testparm utility. +testparm gives warnings for misconfigured settings. Detailed Explanation Settings -The following is a discussion of the settings from Example 20.4.1. +The following is a discussion of the settings from Extended BSD Printing +Configuration Extended BSD Printing Configuration. The [global] Section -The section is one of four special -sections (along with , -, -and ). The - contains all parameters that apply -to the server as a whole. It is the place for parameters that have only a -global meaning. It may also contain service-level parameters that define -default settings for all other sections and shares. This way you can simplify -the configuration and avoid setting the same value repeatedly. (Within each -individual section or share, you may, however, override these globally set -share settings and specify other values). +global section +special sections +individual section +share +The section is one of four special sections (along with , , and ). The + contains all parameters that apply to the server as a whole. It is the place +for parameters that have only a global meaning. It may also contain service-level parameters that define +default settings for all other sections and shares. This way you can simplify the configuration and avoid +setting the same value repeatedly. (Within each individual section or share, you may, however, override these +globally set share settings and specify other values). bsd - Causes Samba to use default print commands - applicable for the BSD (also known as RFC 1179 style or LPR/LPD) printing - system. In general, the printing parameter informs Samba about the - print subsystem it should expect. Samba supports CUPS, LPD, LPRNG, - SYSV, HPUX, AIX, QNX, and PLP. Each of these systems defaults to a - different (and other queue control - commands). - - The parameter is - normally a service-level parameter. Since it is included here in the - section, it will take effect for all - printer shares that are not defined differently. Samba-3 no longer - supports the SOFTQ printing system. + +default print commands +RFC 1179 +printing +CUPS +LPD +LPRNG +SYSV +HPUX +AIX +QNX +PLP +queue control + Causes Samba to use default print commands applicable for the BSD (also known as RFC 1179 style or LPR/LPD) + printing system. In general, the printing parameter informs Samba about the print + subsystem it should expect. Samba supports CUPS, LPD, LPRNG, SYSV, HPUX, AIX, QNX, and PLP. Each of these + systems defaults to a different (and other queue control commands). + + + +service-level +SOFTQ printing system + The parameter is normally a service-level parameter. Since it is included + here in the section, it will take effect for all printer shares that are not + defined differently. Samba-3 no longer supports the SOFTQ printing system. + yes - Tells Samba to create automatically all - available printer shares. Available printer shares are discovered by - scanning the printcap file. All created printer shares are also loaded - for browsing. If you use this parameter, you do not need to specify - separate shares for each printer. Each automatically created printer - share will clone the configuration options found in the - section. (The load printers - = no setting will allow you to specify each UNIX printer - you want to share separately, leaving out some you do not want to be - publicly visible and available). + +printer shares +printcap +separate shares +UNIX printer + Tells Samba to create automatically all available printer shares. Available printer shares are discovered by + scanning the printcap file. All created printer shares are also loaded for browsing. If you use this + parameter, you do not need to specify separate shares for each printer. Each automatically created printer + share will clone the configuration options found in the section. (The + load printers = no setting will allow you to specify each UNIX printer you want to + share separately, leaving out some you do not want to be publicly visible and available). + yes - Setting is normally enabled by default (even if the parameter is not specified in &smb.conf;). - It causes the Add Printer Wizard icon to appear - in the Printers folder of the Samba host's - share listing (as shown in Network Neighborhood or - by the net view command). To disable it, you need to - explicitly set it to no (commenting it out - will not suffice). The Add Printer Wizard lets you upload a printer - driver to the share and associate it - with a printer (if the respective queue exists before the - action), or exchange a printer's driver for any other previously - uploaded driver. + +Add Printer Wizard +Printers +Network Neighborhood +net view +uploaded driver + Setting is normally enabled by default (even if the parameter is not specified in &smb.conf;). It causes the + Add Printer Wizard icon to appear in the Printers folder of the Samba + host's share listing (as shown in Network Neighborhood or by the net + view command). To disable it, you need to explicitly set it to no (commenting + it out will not suffice). The Add Printer Wizard lets you upload a printer driver to + the share and associate it with a printer (if the respective queue exists + before the action), or exchange a printer's driver for any other previously uploaded driver. + 100 - Sets the upper limit to 100 print jobs - being active on the Samba server at any one time. Should a client - submit a job that exceeds this number, a "no more space - available on server" type of error message will be returned by - Samba to the client. A setting of zero (the default) means there is - no limit at all. - + +print jobs + Sets the upper limit to 100 print jobs being active on the Samba server at any one time. Should a client + submit a job that exceeds this number, a "no more space available on server" type of error message will be + returned by Samba to the client. A setting of zero (the default) means there is no limit + at all. + + /etc/printcap - Tells Samba where to look for a list of - available printer names. Where CUPS is used, make sure that a printcap - file is written. This is controlled by the Printcap directive in the + +CUPS +available printerd +printcap + Tells Samba where to look for a list of available printer names. Where CUPS is used, make sure that a printcap + file is written. This is controlled by the Printcap directive in the cupsd.conf file. @ntadmin - Members of the ntadmin group should be able to add - drivers and set printer properties (ntadmin is only an example name; - it needs to be a valid UNIX group name); root is implicitly always a - . The @ sign precedes group names in the - /etc/group. A printer admin can do anything to - printers via the remote administration interfaces offered by MS-RPC - (see Printing Developments Since Samba-2.2). - In larger installations, the parameter is normally - a per-share parameter. This permits different groups to administer each printer share. + +add drivers +/etc/group +printer share +set printer properties + Members of the ntadmin group should be able to add drivers and set printer properties + (ntadmin is only an example name; it needs to be a valid UNIX group name); root is + implicitly always a . The @ sign precedes group names + in the /etc/group. A printer admin can do anything to printers via the remote + administration interfaces offered by MS-RPC (see Printing Developments Since + Samba-2.2). In larger installations, the parameter is normally a + per-share parameter. This permits different groups to administer each printer share. 20 - Controls the cache time for the results of the - lpq command. It prevents the lpq command being called too often and - reduces the load on a heavily used print server. + +lpq command +lpq cache time + Controls the cache time for the results of the lpq command. It prevents the lpq command being called too often + and reduces the load on a heavily used print server. no - If set to yes, only - takes effect for Windows NT/200x/XP clients (and not for Win 95/98/ME). Its - default value is No (or False). - It must not be enabled on print shares - (with a yes or true setting) that - have valid drivers installed on the Samba server. For more detailed + +Windows NT/200x/XP + If set to yes, only takes effect for Windows NT/200x/XP clients (and not for Win + 95/98/ME). Its default value is No (or False). It must + not be enabled on print shares (with a yes or + true setting) that have valid drivers installed on the Samba server. For more detailed explanations, see the &smb.conf; man page. @@ -609,14 +665,14 @@ share settings and specify other values). The [printers] Section -The printers section is the second special section. If a section with this name appears in -the &smb.conf;, users are able to connect to any printer specified in the -Samba host's printcap file, because Samba on startup then creates a printer -share for every printer name it finds in the printcap file. You could regard -this section as a convenient shortcut to share all printers with -minimal configuration. It is also a container for settings that should -apply as default to all printers. (For more details, see the &smb.conf; -man page.) Settings inside this container must be share-level parameters. +printers section +printcap +The printers section is the second special section. If a section with this name appears in the &smb.conf;, +users are able to connect to any printer specified in the Samba host's printcap file, because Samba on startup +then creates a printer share for every printer name it finds in the printcap file. You could regard this +section as a convenient shortcut to share all printers with minimal configuration. It is also a container for +settings that should apply as default to all printers. (For more details, see the &smb.conf; man page.) +Settings inside this container must be share-level parameters. @@ -709,6 +765,8 @@ man page.) Settings inside this container must be share-level parameters. Any [my_printer_name] Section +loading printer drivers +name conflict If a [my_printer_name] section appears in the &smb.conf; file, which includes the parameter yes Samba will configure it as a printer share. Windows 9x/Me clients may have problems with connecting or loading printer drivers if the share name has more @@ -759,9 +817,9 @@ finds one, it will connect to this and will not connect to a printer with the sa 10.160.50.,10.160.51. - Here we exercise a certain degree of access control by using the and - parameters. This is not by any means a safe bet. It is not a way to secure your - printers. This line accepts all clients from a certain subnet in a first evaluation of + Here we exercise a certain degree of access control by using the + and parameters. This is not by any means a safe bet. It is not a + way to secure your printers. This line accepts all clients from a certain subnet in a first evaluation of access control. @@ -785,6 +843,10 @@ finds one, it will connect to this and will not connect to a printer with the sa Print Commands +print command +print subsystem +temporary location +shell scripts In each section defining a printer (or in the section), a print command parameter may be defined. It sets a command to process the files that have been placed into the Samba print spool directory for that printer. (That spool directory was, @@ -803,6 +865,7 @@ your hard disk may soon suffer from shortage of free space. Default UNIX System Printing Commands +default print command You learned earlier that Samba, in most cases, uses its built-in settings for many parameters if it cannot find an explicitly stated one in its configuration file. The same is true for the . The default print command varies depending on the parameter @@ -891,13 +954,16 @@ linkend="CUPS-printing">CUPS Printing Support. -For -printing = CUPS, if Samba is compiled against libcups, it uses the CUPS API to submit -jobs. (It is a good idea also to set cups -in case your cupsd.conf is set to write its autogenerated printcap file to an -unusual place). Otherwise, Samba maps to the System V printing commands with the -oraw option for printing; -that is, it uses lp -c -d%p -oraw; rm %s. With printing = cups, -and if Samba is compiled against libcups, any manually set print command will be ignored! +CUPS API +cupsd.conf +autogenerated printcap +libcups +For printing = CUPS, if Samba is compiled against libcups, it uses the CUPS API to +submit jobs. (It is a good idea also to set cups in case your +cupsd.conf is set to write its autogenerated printcap file to an unusual place). +Otherwise, Samba maps to the System V printing commands with the -oraw option for printing; that is, it uses +lp -c -d%p -oraw; rm %s. With printing = cups, and if Samba is +compiled against libcups, any manually set print command will be ignored! @@ -906,24 +972,28 @@ and if Samba is compiled against libcups, any manually set print command will be Custom Print Commands -After a print job has finished spooling to a service, the - will be used by Samba via a system() call to process the -spool file. Usually the command specified will submit the spool file to the host's printing subsystem. But -there is no requirement at all that this must be the case. The print subsystem may not remove the spool -file on its own, so whatever command you specify, you should ensure that the spool file is deleted after -it has been processed. +print job +spooling +After a print job has finished spooling to a service, the will be used +by Samba via a system() call to process the spool file. Usually the command specified will submit the spool +file to the host's printing subsystem. But there is no requirement at all that this must be the case. The +print subsystem may not remove the spool file on its own, so whatever command you specify, you should ensure +that the spool file is deleted after it has been processed. -There is no difficulty with using your own customized print commands with the traditional printing -systems. However, if you do not wish to roll your own, you should be well informed about the default -built-in commands that Samba uses for each printing subsystem (see -Table 17.1). In all the -commands listed in the last paragraphs, you see parameters of the form %X. These are -macros, or shortcuts, used as placeholders for the names of real objects. At the time -of running a command with such a placeholder, Samba will insert the appropriate value automatically. Print -commands can handle all Samba macro substitutions. In regard to printing, the following ones do have -special relevance: +traditional printing +customized print commands +built-in commands +macros +There is no difficulty with using your own customized print commands with the traditional printing systems. +However, if you do not wish to roll your own, you should be well informed about the default built-in commands +that Samba uses for each printing subsystem (see Default Printing +Settings). In all the commands listed in the last paragraphs, you see parameters of the form +%X. These are macros, or shortcuts, used as placeholders for the +names of real objects. At the time of running a command with such a placeholder, Samba will insert the +appropriate value automatically. Print commands can handle all Samba macro substitutions. In regard to +printing, the following ones do have special relevance: @@ -935,6 +1005,7 @@ special relevance: +default printer The print command must contain at least one occurrence of %s or %f. The %p is optional. If no printer name is supplied, the %p will be silently removed from the print command. In this case, the job is @@ -942,6 +1013,8 @@ sent to the default printer. +global print command +spool files If specified in the section, the print command given will be used for any printable service that does not have its own print command specified. If there is neither a specified print command for a printable service nor a global print command, spool files will be created @@ -949,12 +1022,17 @@ but not processed! Most importantly, print files will not be removed, so they wi +nobody account +guest account Printing may fail on some UNIX systems when using the nobody account. If this happens, create an alternative guest account and give it the privilege to print. Set up this guest account in the section with the guest account parameter. +environment variables +print commands +print job You can form quite complex print commands. You need to realize that print commands are just passed to a UNIX shell. The shell is able to expand the included environment variables as usual. (The syntax to include a UNIX environment variable $variable @@ -986,6 +1064,9 @@ parameter. Another example is: Printing Developments Since Samba-2.2 +LanMan +MS-RPC +SPOOLSS Prior to Samba-2.2.x, print server support for Windows clients was limited to LanMan printing calls. This is the same protocol level as Windows 9x/Me PCs offer when they share printers. Beginning with the 2.2.0 release, Samba started to support the native Windows NT printing mechanisms. These @@ -999,37 +1080,49 @@ The additional functionality provided by the new SPOOLSS support includes: +Point'n'Print Support for downloading printer driver files to Windows 95/98/NT/2000 clients upon demand (Point'n'Print). +Add Printer Wizard Uploading of printer drivers via the Windows NT Add Printer Wizard (APW) or the Imprints tool set. - - Support for the native MS-RPC printing calls such as - StartDocPrinter, EnumJobs(), and so on. (See the + +MS-RPC +printing calls +StartDocPrinter +EnumJobs() +Win32 printing API + Support for the native MS-RPC printing calls such as StartDocPrinter, EnumJobs(), and so on. (See the MSDN documentation for more information on the Win32 printing API). +ACL +printer objects Support for NT Access Control Lists (ACL) on printer objects. +printer queue Improved support for printer queue manipulation through the use of internal databases for spooled job information (implemented by various *.tdb files). +ADS +LDAP A benefit of updating is that Samba-3 is able to publish its printers to Active Directory (or LDAP). +publish printers A fundamental difference exists between MS Windows NT print servers and Samba operation. Windows NT permits the installation of local printers that are not shared. This is an artifact of the fact that any Windows NT machine (server or client) may be used by a user as a workstation. Samba will publish all @@ -1037,6 +1130,11 @@ printers that are made available, either by default or by specific declaration v +SMB +MS-RPC +Everyone group +privileges +printer default permissions Windows NT/200x/XP Professional clients do not have to use the standard SMB printer share; they can print directly to any printer on another Windows NT host using MS-RPC. This, of course, assumes that the client has the necessary privileges on the remote host that serves the printer resource. The @@ -1049,12 +1147,15 @@ printers.) Point'n'Print Client Drivers on Samba Servers +printer drivers There is much confusion about what all this means. The question is often asked, Is it or is it not necessary for printer drivers to be installed on a Samba host in order to support printing from Windows clients? The answer to this is no, it is not necessary. +install drivers +print queue Windows NT/2000 clients can, of course, also run their APW to install drivers locally (which then connect to a Samba-served print queue). This is the same method used by Windows 9x/Me clients. (However, a bug existed in Samba 2.2.0 that made Windows NT/2000 clients @@ -1062,6 +1163,8 @@ require that the Samba server possess a valid driver for the printer. This was f +printer drivers +uploading But it is a new capability to install the printer drivers into the share of the Samba server, and a big convenience, too. Then all clients (including 95/98/ME) get the driver installed when they first connect to this printer share. The @@ -1084,12 +1187,13 @@ Samba printer share can be achieved by different means: - Using cupsaddsmb (only works for the CUPS - printing system, not for LPR/LPD, LPRng, and so on). + Using cupsaddsmb (only works for the CUPS printing system, not for LPR/LPD, LPRng, and so on). +uploaded drivers +Point'n'Print Samba does not use these uploaded drivers in any way to process spooled files. These drivers are utilized entirely by the clients who download and install them via the Point'n'Print mechanism supported by Samba. The clients use these drivers to generate print files in the format the printer @@ -1102,18 +1206,22 @@ system, which is responsible for all further processing, as needed. The Obsoleted [printer$] Section - Versions of Samba prior to 2.2 made it possible to use a share named - [printer$]. This name was taken from the same named service created by - Windows 9x/Me clients when a printer was shared by them. Windows 9x/Me printer servers always - have a service that provides read-only access (with - no password required) to support printer driver downloads. However, Samba's initial - implementation allowed for a parameter named printer driver location to - be used on a per-share basis. This specified the location of the driver files associated with - that printer. Another parameter named printer driver provided a means of - defining the printer driver name to be sent to the client. +printer$ share +printer driver + Versions of Samba prior to 2.2 made it possible to use a share named [printer$]. This + name was taken from the same named service created by Windows 9x/Me clients when a printer was shared by them. + Windows 9x/Me printer servers always have a service that provides + read-only access (with no password required) to support printer driver downloads. However, Samba's initial + implementation allowed for a parameter named printer driver location to be used on a + per-share basis. This specified the location of the driver files associated with that printer. Another + parameter named printer driver provided a means of defining the printer driver name to + be sent to the client. +printer driver file +read-write access +ACLs These parameters, including the printer driver file parameter, are now removed and cannot be used in installations of Samba-3. The share name is now used for the location of downloadable printer @@ -1130,6 +1238,7 @@ system, which is responsible for all further processing, as needed. Creating the [print$] Share +printer driver In order to support the uploading and downloading of printer driver files, you must first configure a file share named . The public name of this share is hard coded in the MS Windows clients. It cannot be renamed, since Windows clients are programmed to search for a @@ -1140,7 +1249,7 @@ service of exactly this name if they want to retrieve printer driver files. You should modify the server's file to add the global parameters and create the file share (of course, some of the parameter values, such as , are arbitrary and should be replaced with appropriate values for your -site). See Example 20.5.1. +site). See [print\$] Example. @@ -1172,6 +1281,10 @@ Of course, you also need to ensure that the directory named by the [print$] Section Parameters +special section +potential printer +driver download +local print driver The is a special section in &smb.conf;. It contains settings relevant to potential printer driver download and is used by Windows clients for local print driver installation. The following parameters are frequently needed in this share section: @@ -1215,8 +1328,9 @@ The following parameters are frequently needed in this share section: validated by the domain controller in order to log on to the Windows NT session), then guest access is not necessary. Of course, in a workgroup environment where you just want to print without worrying about silly accounts and security, then configure the share for - guest access. You should consider adding Bad User in the section - as well. Make sure you understand what this parameter does before using it. + guest access. You should consider adding Bad User + in the section as well. Make sure you understand what this + parameter does before using it. @@ -1262,9 +1376,7 @@ not need to support). Therefore, create a directory tree below the share for each architecture you wish to support like this: - - - + [print$]--+ |--W32X86 # serves drivers to Windows NT x86 |--WIN40 # serves drivers to Windows 95/98 @@ -1309,14 +1421,13 @@ an initial listing of printers that matches the printer shares defined on your S Installing Drivers into [print$] -Have you successfully created the share in &smb.conf;, and have you forced Samba -to reread its &smb.conf; file? Good. But you are not yet ready to use the new facility. The client driver -files need to be installed into this share. So far, it is still an empty share. Unfortunately, it is -not enough to just copy the driver files over. They need to be -correctly installed so that appropriate -records for each driver will exist in the Samba internal databases so it can provide the correct -drivers as they are requested from MS Windows clients. And that is a bit tricky, to say the least. We -now discuss two alternative ways to install the drivers into : +Have you successfully created the share in &smb.conf;, and have you forced +Samba to reread its &smb.conf; file? Good. But you are not yet ready to use the new facility. The client +driver files need to be installed into this share. So far, it is still an empty share. Unfortunately, it is +not enough to just copy the driver files over. They need to be correctly installed so that appropriate records +for each driver will exist in the Samba internal databases so it can provide the correct drivers as they are +requested from MS Windows clients. And that is a bit tricky, to say the least. We now discuss two alternative +ways to install the drivers into : @@ -1427,6 +1538,9 @@ We provide detailed hints for each of these steps in the paragraphs that follow. Identifying Driver Files +driver files +driver CDROM +inf file To find out about the driver files, you have two options. You can check the contents of the driver CDROM that came with your printer. Study the *.inf files located on the CD-ROM. This may not be possible, since the *.inf file might be missing. Unfortunately, vendors have now started @@ -1436,6 +1550,7 @@ extremely difficult to identify the driver files required. +W32X86 Then you have the second option. Install the driver locally on a Windows client and investigate which filenames and paths it uses after they are installed. (You need to repeat this procedure for every client platform you want to support. We show it here for the @@ -1444,6 +1559,7 @@ clients.) +driver files A good method to recognize the driver files is to print the test page from the driver's Properties dialog (General tab). Then look at the list of driver files named on the printout. You'll need to recognize what Windows (and Samba) are calling the @@ -1453,6 +1569,9 @@ driver files named on the printout. You'll need to recognize what Windows (and S +rpcclient +enumdrivers +getdriver Another method to quickly test the driver filenames and related paths is provided by the rpcclient utility. Run it with enumdrivers or with the getdriver subcommand, each at the 3 info level. In the following example, @@ -1497,17 +1616,24 @@ Printer Driver Info 3: +Driver File +Driver Path +WIN40 +W32X86 You may notice that this driver has quite a large number of Dependent files (there are worse cases, however). Also, strangely, the Driver File is tagged here Driver Path. We do not yet have support for the so-called WIN40 architecture installed. This name is used by Microsoft for the Windows 9x/Me platforms. If we want to support these, we need to install the Windows 9x/Me driver files in -addition to those for W32X86 (i.e., the Windows NT72000/XP clients) onto a +addition to those for W32X86 (i.e., the Windows NT 2000/XP clients) onto a Windows PC. This PC can also host the Windows 9x/Me drivers, even if it runs on Windows NT, 2000, or XP. +UNC notation +Windows Explorer + Since the share is usually accessible through the Network Neighborhood, you can also use the UNC notation from Windows Explorer to poke at it. The Windows 9x/Me driver files will end up in subdirectory 0 of the WIN40 @@ -1532,9 +1658,7 @@ from? Well, why not retrieve them from the very PC and the same smbclient to do this. We will use the paths and names that were leaked to us by getdriver. The listing is edited to include line breaks for readability: - - - + &rootprompt;smbclient //TURBO_XP/print\$ -U'Danka%xxxx' \ -c 'cd W32X86/2;mget HD*_de.* hd*ppd Hd*_de.* Hddm*dll HDN*Aux.DLL' @@ -1557,6 +1681,7 @@ This ensures that all commands are executed in sequence on the remote Windows se +WIN40 Remember to repeat the procedure for the WIN40 architecture should you need to support Windows 9x/Me/XP clients. Remember too, the files for these architectures are in the WIN40/0/ subdirectory. Once this is complete, we can run smbclient. . @@ -1588,13 +1713,13 @@ driver files should now go here: +smbclient +getdriver We again use smbclient to transfer the driver files across the network. We specify the same files and paths as were leaked to us by running getdriver against the original Windows install. However, now we are going to store the files into a Samba/UNIX print server's share. - - - + &rootprompt;smbclient //SAMBA-CUPS/print\$ -U'root%xxxx' -c \ 'cd W32X86; put HDNIS01_de.DLL; \ put Hddm91c1_de.ppd; put HDNIS01U_de.DLL; \ @@ -1626,7 +1751,9 @@ putting file Hddm91c1_de_reg.HLP as \W32X86\Hddm91c1_de_reg.HLP putting file HDNIS01Aux.dll as \W32X86\HDNIS01Aux.dll putting file HDNIS01_de.NTF as \W32X86\HDNIS01_de.NTF - +PPD +PostScript driver +adddriver Whew &smbmdash; that was a lot of typing! Most drivers are a lot smaller &smbmdash; many have only three generic PostScript driver files plus one PPD. While we did retrieve the files from the 2 subdirectory of the W32X86 directory from the Windows box, we do not put them @@ -1634,12 +1761,15 @@ subdirectory of the W32X86 directory from the Windows box, adddriver command, which we will run shortly (and do not forget to also put the files for the Windows 9x/Me architecture into the WIN40/ subdirectory should you need them). + <command>smbclient</command> to Confirm Driver Installation +smbclient +SSH For now we verify that our files are there. This can be done with smbclient, too (but, of course, you can log in via SSH also and do this through a standard UNIX shell access): @@ -1684,14 +1814,16 @@ PDFcreator2.PPD A 15746 Sun Apr 20 22:24:07 2003 -Notice that there are already driver files present in the 2 subdirectory (probably -from a previous installation). Once the files for the new driver are there too, you are still a few -steps away from being able to use them on the clients. The only thing you could do now is retrieve -them from a client just like you retrieve ordinary files from a file share, by opening print$ in Windows -Explorer. But that wouldn't install them per Point'n'Print. The reason -is that Samba does not yet know that -these files are something special, namely printer driver files, and it does not know -to which print queue(s) these driver files belong. +Point'n'Print +printer driver files +print queue +Notice that there are already driver files present in the 2 subdirectory (probably from a +previous installation). Once the files for the new driver are there too, you are still a few steps away from +being able to use them on the clients. The only thing you could do now is retrieve them from a client just +like you retrieve ordinary files from a file share, by opening print$ in Windows Explorer. But that wouldn't +install them per Point'n'Print. The reason is that Samba does not yet know that these files are something +special, namely printer driver files, and it does not know to which print queue(s) these +driver files belong. @@ -1699,13 +1831,14 @@ to which print queue(s) these driver files belong. Running <command>rpcclient</command> with <command>adddriver</command> +adddriver +register driver files +TDB database Next, you must tell Samba about the special category of the files you just uploaded into the share. This is done by the adddriver command. It will prompt Samba to register the driver files into its internal TDB database files. The following command and its output has been edited for readability: - - - + &rootprompt;rpcclient -Uroot%xxxx -c 'adddriver "Windows NT x86" \ "dm9110:HDNIS01_de.DLL: \ Hddm91c1_de.ppd:HDNIS01U_de.DLL:HDNIS01U_de.HLP: \ @@ -1726,6 +1859,9 @@ Printer Driver dm9110 successfully installed. +NT_STATUS_UNSUCCESSFUL +error message +adddriver After this step, the driver should be recognized by Samba on the print server. You need to be very careful when typing the command. Don't exchange the order of the fields. Some changes would lead to an NT_STATUS_UNSUCCESSFUL error message. These become obvious. Other @@ -1743,9 +1879,7 @@ One indication for Samba's recognition of the files as driver files is the message. Another one is the fact that our files have been moved by the adddriver command into the 2 subdirectory. You can check this again with smbclient: - - - + &rootprompt;smbclient //SAMBA-CUPS/print\$ -Uroot%xx \ -c 'cd W32X86;dir;pwd;cd 2;dir;pwd' added interface ip=10.160.51.162 bcast=10.160.51.255 nmask=255.255.252.0 @@ -1794,6 +1928,7 @@ Another verification is that the timestamp of the printing TDB files is now upda Check Samba for Driver Recognition +registered Now the driver should be registered with Samba. We can easily verify this and will do so in a moment. However, this driver is not yet associated with a particular printer. We may check the driver status of the files by at least three methods: @@ -1801,6 +1936,11 @@ status of the files by at least three methods: +Network Neighborhood +Printers and Faxes +printer icon +Windows95/98/ME +Windows NT/2000/XP From any Windows client browse Network Neighborhood, find the Samba host, and open the Samba Printers and Faxes folder. Select any printer icon, right-click and select the printer Properties. Click the Advanced @@ -1812,35 +1952,36 @@ status of the files by at least three methods: +Network Neighborhood From a Windows 200x/XP client (not Windows NT) browse Network Neighborhood, search for the Samba server, open the server's Printers folder, and right-click on the white background (with no printer highlighted). Select Server Properties. On the Drivers tab you will see the new driver listed. This view enables you to also inspect the list of files belonging to that driver (this does not work on Windows NT, but only on Windows 2000 and Windows XP; Windows NT does not - provide the Drivers tab). An - alternative and much quicker method for + provide the Drivers tab). An alternative and much quicker method for Windows 2000/XP to start this dialog is by typing into a DOS box (you must of course adapt the name to your Samba server instead of SAMBA-CUPS): + + rundll32 printui.dll,PrintUIEntry /s /t2 /n\\SAMBA-CUPS + - - rundll32 printui.dll,PrintUIEntry /s /t2 /n\\SAMBA-CUPS From a UNIX prompt, run this command (or a variant thereof), where SAMBA-CUPS is the name of the Samba host and xxxx represents the actual Samba password assigned to root: + + rpcclient -U'root%xxxx' -c 'enumdrivers' SAMBA-CUPS + - rpcclient -U'root%xxxx' -c 'enumdrivers' SAMBA-CUPS - You will see a listing of all drivers Samba knows about. Your new one should be among them. But it is only listed under the [Windows NT x86] heading, not under , since you didn't install that part. Or did you? - In - our example it is named dm9110. Note that the third column shows the other + In our example it is named dm9110. Note that the third column shows the other installed drivers twice, one time for each supported architecture. Our new driver only shows up for Windows NT 4.0 or 2000. To have it present for Windows 95, 98, and Me, you'll have to repeat the whole procedure with the WIN40 architecture @@ -1853,11 +1994,10 @@ status of the files by at least three methods: Specific Driver Name Flexibility +adddriver You can name the driver as you like. If you repeat the adddriver step with the same files as before but with a different driver name, it will work the same: - - - + &rootprompt;rpcclient -Uroot%xxxx \ -c 'adddriver "Windows NT x86" \ "mydrivername:HDNIS01_de.DLL: \ @@ -1879,6 +2019,9 @@ Printer Driver mydrivername successfully installed. +print queue +rpcclient +adddriver You will be able to bind that driver to any print queue (however, you are responsible that you associate drivers to queues that make sense with respect to target printers). You cannot run the rpcclient adddriver command repeatedly. Each run consumes the @@ -1889,15 +2032,15 @@ each rpcclient ... adddriver command. -Running <command>rpcclient</command> with the <command>setdriver</command> +Running <command>rpcclient</command> with <command>setdriver</command> - + +mapping printer driver +TDB Samba needs to know which printer owns which driver. Create a mapping of the driver to a printer, and store this information in Samba's memory, the TDB files. The rpcclient setdriver command achieves exactly this: - - - + &rootprompt;rpcclient -U'root%xxxx' -c 'setdriver dm9110 mydrivername' SAMBA-CUPS cmd = setdriver dm9110 mydrivername @@ -1906,9 +2049,7 @@ Successfully set dm9110 to driver mydrivername. Ah, no, I did not want to do that. Repeat, this time with the name I intended: - - - + &rootprompt;rpcclient -U'root%xxxx' -c 'setdriver dm9110 dm9110' SAMBA-CUPS cmd = setdriver dm9110 dm9110 Successfully set dm9110 to driver dm9110. @@ -1924,8 +2065,7 @@ Now we have done most of the work, but not all of it. -The setdriver command will only succeed if the -printer is already known to Samba. A +The setdriver command will only succeed if the printer is already known to Samba. A bug in 2.2.x prevented Samba from recognizing freshly installed printers. You had to restart Samba, or at least send an HUP signal to all running smbd processes to work around this: kill -HUP `pidof smbd`. @@ -1949,8 +2089,8 @@ not as straightforward as it may seem. Read on. Especially important is the installation onto the first client PC (for each architectural platform separately). Once this is done correctly, all further clients are easy to set up and shouldn't need further -attention. What follows is a description for the recommended first procedure. You work now from a client -workstation. You should guarantee that your connection is not unwittingly mapped to bad +attention. What follows is a description for the recommended first procedure. You now work from a client +workstation. You should check that your connection is not unwittingly mapped to bad user nobody. In a DOS box type: @@ -2000,9 +2140,10 @@ and Faxes). +print test page Most likely you are tempted to try to print a test page. After all, you now can open the printer properties, and on the General tab there is a button offering to do just that. But -chances are that you get an error message saying "Unable to print Test Page." The +chances are that you get an error message saying "Unable to print Test Page." The reason might be that there is not yet a valid device mode set for the driver or that the printer driver data set is still incomplete. @@ -2022,16 +2163,23 @@ For a printer to be truly usable by a Windows NT/200x/XP client, it must possess +device mode A valid device mode generated by the driver for the printer (defining things like paper size, orientation and duplex settings). +printer driver data A complete set of printer driver data generated by the driver. +ntprinters.tdb +ntdrivers.tdb +printing.tdb +ntforms.tdb +TDB database files If either of these is incomplete, the clients can produce less than optimal output at best. In the worst cases, unreadable garbage or nothing at all comes from the printer, or it produces a harvest of error messages when attempting to print. Samba stores the named values and all printing-related information in @@ -2049,13 +2197,12 @@ in the following paragraphs. -Be aware that a valid device mode can only be initiated by a - or root -(the reason should be obvious). Device modes can be correctly -set only by executing the printer driver program itself. Since Samba cannot execute this Win32 platform driver -code, it sets this field initially to NULL (which is not a valid setting for clients to use). Fortunately, -most drivers automatically generate the printer driver data that is needed when they are uploaded to the - share with the help of the APW or rpcclient. +Be aware that a valid device mode can only be initiated by a or root +(the reason should be obvious). Device modes can be correctly set only by executing the printer driver program +itself. Since Samba cannot execute this Win32 platform driver code, it sets this field initially to NULL +(which is not a valid setting for clients to use). Fortunately, most drivers automatically generate the +printer driver data that is needed when they are uploaded to the share with +the help of the APW or rpcclient. @@ -2121,6 +2268,7 @@ folder, too, if you are a Samba printer admin user. From now on, printing should +default devmode Samba includes a service-level parameter name default devmode for generating a default device mode for a printer. Some drivers function well with Samba's default set of properties. Others may crash the client's spooler service. So use this parameter with caution. It is always better to have @@ -2132,29 +2280,27 @@ the client generate a valid device mode for the printer and store it on the serv Additional Client Driver Installation -Every additional driver may be installed in the same way as just described. -Browse Network Neighborhood, open the -Printers folder on Samba server, right-click on Printer, and choose -Connect.... Once this completes (should be not more than a few seconds, -but could also take a minute, depending on network conditions), you should find the new printer in your -client workstation local Printers and Faxes folder. +additional driver +Every additional driver may be installed in the same way as just described. Browse Network +Neighborhood, open the Printers folder on Samba server, right-click on +Printer, and choose Connect.... Once this completes (should be +not more than a few seconds, but could also take a minute, depending on network conditions), you should find +the new printer in your client workstation local Printers and Faxes folder. You can also open your local Printers and Faxes folder by using this command on Windows 200x/XP Professional workstations: - - -rundll32 shell32.dll,SHHelpShortcuts_RunDLL PrintersFolder - - + +rundll32 shell32.dll,SHHelpShortcuts_RunDLL PrintersFolder + or this command on Windows NT 4.0 workstations: +rundll32 + +rundll32 shell32.dll,Control_RunDLL MAIN.CPL @2 + - -rundll32 shell32.dll,Control_RunDLL MAIN.CPL @2 - - You can enter the commands either inside a DOS box window or in the Run command... field from the Start menu. @@ -2165,9 +2311,10 @@ command... field from the Start menu. Always Make First Client Connection as root or <quote>printer admin</quote> -After you installed the driver on the Samba server (in its -share), you should always make sure that your first client installation completes correctly. Make it a -habit for yourself to build the very first connection from a client as . This is to make sure that: +After you installed the driver on the Samba server (in its share), you +should always make sure that your first client installation completes correctly. Make it a habit for yourself +to build the very first connection from a client as . This is to make +sure that: @@ -2189,26 +2336,25 @@ printer for duplex as the default, and so on). +runas To connect as root to a Samba printer, try this command from a Windows 200x/XP DOS box command prompt: - - - + &dosprompt;runas /netonly /user:root "rundll32 printui.dll,PrintUIEntry /p /t3 /n \\SAMBA-SERVER\printername" -You will be prompted for root's Samba password; type it, wait a few -seconds, click on Printing -Defaults, and proceed to set the job options that should be used as defaults by all -clients. Alternatively, instead of root you can name one other member of the from the setting. +You will be prompted for root's Samba password; type it, wait a few seconds, click on +Printing Defaults, and proceed to set the job options that should be used as defaults +by all clients. Alternatively, instead of root you can name one other member of the from the setting. - Now all the other users downloading and installing the driver the same way (using -Point'n'Print) will have the same defaults set for them. If you miss this step, -you'll get a lot of help desk calls from your users, but maybe you like to talk to people. +Now all the other users downloading and installing the driver the same way (using +Point'n'Print) will have the same defaults set for them. If you miss this step, you'll get a +lot of help desk calls from your users, but maybe you like to talk to people. @@ -2217,27 +2363,23 @@ you'll get a lot of help desk calls from your users, but maybe you like to talk Other Gotchas -Your driver is installed. It is now ready for Point'n'Print -installation by the clients. You may have tried to download and use it -on your first client machine, but -wait. Let's make sure you are acquainted first with a few tips and tricks you may find useful. For example, -suppose you did not set the defaults on the printer, as advised in the preceding -paragraphs. Your users complain about various issues (such as, We need to set the paper size -for each job from Letter to A4 and it will not store it). +Your driver is installed. It is now ready for Point'n'Print installation by the clients. You may have tried to +download and use it on your first client machine, but wait. Let's make sure you are acquainted first with a +few tips and tricks you may find useful. For example, suppose you did not set the defaults on the printer, as +advised in the preceding paragraphs. Your users complain about various issues (such as, We need to set +the paper size for each job from Letter to A4 and it will not store it). Setting Default Print Options for Client Drivers -The last sentence might be viewed with mixed feelings by some users and -Admins. They have struggled for hours and could not arrive at a point -where their settings seemed to be saved. It is not their fault. The confusing -thing is that in the multitabbed dialog that pops up when you right-click -on the printer name and select Properties, you -can arrive at two dialogs that appear identical, each claiming that they help -you to set printer options in three different ways. Here is the definitive -answer to the Samba default driver setting FAQ: +The last sentence might be viewed with mixed feelings by some users and Admins. They have struggled for hours +and could not arrive at a point where their settings seemed to be saved. It is not their fault. The confusing +thing is that in the multitabbed dialog that pops up when you right-click on the printer name and select +Properties, you can arrive at two dialogs that appear identical, each claiming that +they help you to set printer options in three different ways. Here is the definitive answer to the Samba +default driver setting FAQ: <quote>I can not set and save default print options @@ -2245,10 +2387,9 @@ for all users on Windows 200x/XP. Why not?</quote> How are you doing it? I bet the wrong way. (It is not easy to find out, though.) There are three different -ways to bring you to a dialog that seems to set everything. All three -dialogs look the same, but only one -of them does what you intend. You need to be Administrator or Print Administrator to do this for all -users. Here is how I reproduce it in an XP Professional: +ways to bring you to a dialog that seems to set everything. All three dialogs look the same, but only one of +them does what you intend. You need to be Administrator or Print Administrator to do this for all users. Here +is how I reproduce it in an XP Professional: @@ -2324,6 +2465,7 @@ defaults for all users. Try (on Windows 200x/XP) to run this command (as a user with the right privileges): +rundll32 @@ -2498,25 +2640,27 @@ The APW can do various things: -The last one (add a new printer) requires more effort than the previous ones. To use -the APW to successfully add a printer to a Samba server, the must have a defined value. The program hook must successfully -add the printer to the UNIX print system (i.e., to /etc/printcap, -/etc/cups/printers.conf or other appropriate files) and to &smb.conf; if necessary. +The last one (add a new printer) requires more effort than the previous ones. To use the APW to successfully +add a printer to a Samba server, the must have a defined value. +The program hook must successfully add the printer to the UNIX print system (i.e., to +/etc/printcap, /etc/cups/printers.conf or other appropriate files) +and to &smb.conf; if necessary. When using the APW from a client, if the named printer share does not exist, smbd will execute the - and reparse to attempt to locate the new printer -share. If the share is still not defined, an error of "Access Denied" is returned to -the client. The is executed -under the context of the connected user, not necessarily a root account. A bad user may have connected you unwittingly under the wrong -privilege. You should check it by using the smbstatus command. + and reparse to attempt to locate the new printer share. If the +share is still not defined, an error of "Access Denied" is returned to the client. The + is executed under the context of the connected user, not +necessarily a root account. A bad user may have connected +you unwittingly under the wrong privilege. You should check it by using the smbstatus +command. -Error Message: <quote><errorname>Cannot connect under a different Name</errorname></quote> +Error Message: <quote>Cannot connect under a different Name</quote> Once you are connected with the wrong credentials, there is no means to reverse the situation other than @@ -2525,6 +2669,7 @@ to close all Explorer windows, and perhaps reboot. +net use The net use \\SAMBA-SERVER\sharename /user:root gives you an error message: Multiple connections to a server or a shared resource by the same user utilizing several user names are not allowed. Disconnect all previous connections to the server, @@ -2541,14 +2686,14 @@ to close all Explorer windows, and perhaps reboot. -So you close all connections. You try again. You get the same message. You check from the Samba side, -using smbstatus. Yes, there are more connections. You kill them all. The client -still gives you the same error message. You watch the smbd.log file on a high debug level and try -reconnect. Same error message, but not a single line in the log. You start to wonder if there was a -connection attempt at all. You run ethereal and tcpdump while you try to connect. Result: not a single -byte goes on the wire. Windows still gives the error message. You close all Explorer windows and start it -again. You try to connect &smbmdash; and this times it works! Windows seems to cache connection information somewhere and -does not keep it up to date (if you are unlucky, you might need to reboot to get rid of the error message). +So you close all connections. You try again. You get the same message. You check from the Samba side, using +smbstatus. Yes, there are more connections. You kill them all. The client still gives you +the same error message. You watch the smbd.log file on a high debug level and try reconnect. Same error +message, but not a single line in the log. You start to wonder if there was a connection attempt at all. You +run ethereal and tcpdump while you try to connect. Result: not a single byte goes on the wire. Windows still +gives the error message. You close all Explorer windows and start it again. You try to connect &smbmdash; and +this times it works! Windows seems to cache connection information somewhere and does not keep it up to date +(if you are unlucky, you might need to reboot to get rid of the error message). @@ -2703,9 +2848,8 @@ comparison: -In my example were even more differences than shown here. Conclusion: you must be careful to select -the correct driver files for each driver version. Don't rely on the -names alone, and don't interchange files +In my example were even more differences than shown here. Conclusion: you must be careful to select the +correct driver files for each driver version. Don't rely on the names alone, and don't interchange files belonging to different driver versions. @@ -2714,17 +2858,21 @@ belonging to different driver versions. Samba and Printer Ports +LPT1: +COM1: +FILE: +available port Windows NT/2000 print servers associate a port with each printer. These normally take the form of -LPT1:, COM1:, -FILE:, and so on. Samba must also +LPT1:, COM1:, FILE:, and so on. Samba must also support the concept of ports associated with a printer. By default, only one printer port, named Samba -Printer Port, exists on a system. Samba does not really need such a port in order -to print; rather it is a requirement of Windows clients. They insist on being told about an available -port when they request this information; otherwise, they throw an error message at you. So Samba fakes the port +Printer Port, exists on a system. Samba does not really need such a port in order to +print; rather it is a requirement of Windows clients. They insist on being told about an available port when +they request this information; otherwise, they throw an error message at you. So Samba fakes the port information to keep the Windows clients happy. +Printer Pooling Samba does not support the concept of Printer Pooling internally either. Printer pooling assigns a logical printer to multiple ports as a form of load balancing or failover. @@ -2754,11 +2902,11 @@ Client. The Imprints Toolset -The Imprints tool set provides a UNIX equivalent of the Windows NT APW. -For complete information, please refer to the -Imprints Web site as well as the documentation -included with the Imprints source distribution. This section provides only a brief introduction to -the features of Imprints. +Imprints +The Imprints tool set provides a UNIX equivalent of the Windows NT APW. For complete information, please +refer to the Imprints Web site as well as the +documentation included with the Imprints source distribution. This section provides only a brief introduction +to the features of Imprints. @@ -2888,21 +3036,20 @@ The way of sidestepping this limitation is to require that all Imprints printer Adding Network Printers without User Interaction -The following MS Knowledge Base article may be of some help if you need to handle Windows 2000 -clients: How to Add Printers with No User Interaction in Windows 2000, (http://support.microsoft.com/default.aspx?scid=kb;en-us;189105). -It also applies to Windows XP Professional clients. -The ideas sketched out in this section are inspired by this article, which describes a command-line method that can be -applied to install network and local printers and their drivers. This is most useful if integrated in Logon -Scripts. You can see what options are available by typing in the command prompt (DOS box): +The following MS Knowledge Base article may be of some help if you need to handle Windows 2000 clients: +How to Add Printers with No User Interaction in Windows 2000, (Microsoft KB 189105). It also +applies to Windows XP Professional clients. The ideas sketched out in this section are inspired by this +article, which describes a command-line method that can be applied to install network and local printers and +their drivers. This is most useful if integrated in Logon Scripts. You can see what options are available by +typing in the command prompt (DOS box): rundll32 printui.dll,PrintUIEntry /? A window pops up that shows you all of the command-line switches available. An extensive list of examples -is also provided. This is only for Windows 200x/XP; it does not work on -Windows NT. Windows NT probably has +is also provided. This is only for Windows 200x/XP; it does not work on Windows NT. Windows NT probably has some other tools in the respective Resource Kit. Here is a suggestion about what a client logon script might contain, with a short explanation of what the lines actually do (it works if 200x/XP Windows clients access printers via Samba, and works for Windows-based print servers too): -- cgit