is the configuration file used by papd to configure the printing services offered by netatalk. Please note that papd must be enabled in
for this to take any effect.
shares the same defaults as lpd on many systems, but not Solaris.
Any line not prefixed with
is interpreted. The configuration lines are composed like:
On systems running a System V printing system the simplest case is to have either no papd.conf, or to have one that has no active lines. In this case, atalkd should auto-discover the local printers on the machine. Please note that you can split lines by using
printername may be just a name (Printer 1), or it may be a full name in nbp_name format (Printer 1:LaserWriter@My Zone).
Systems using a BSD printing system should make use of a pipe to the printing command in question within the
When CUPS support is compiled in, then
as the first entry in papd.conf will automagically share all CUPS printers by papd utilizing the PPDs assigned in CUPS (customizable -- see below). This can be overwritten for individal printers by subsequently adding individual entries using the CUPS queue name as
entry. Note: CUPS support is mutually exclusive with System V support described above.
The possible options are colon delimited (:), and lines must be terminated with colons. The possible options and flags are:
option allows specific UAMs to be specified for a particular printer. It has no effect if the
flag is not present or if papd authentication was not built into netatalk. Note: possible values are
only. The first method requires a valid username, but no password. The second requires both a valid username and the correct password.
If present, this flag enables authentication for the printer. Please note that papd authentication must be built into netatalk for this to take effect.
option allows options to be passed through to CUPS (eg.
If used as the first entry in papd.conf this will share all CUPS printers via papd. type/zone settings as well as other parameters assigned to this special printer share will apply to all CUPS printers. Unless the
option is set, the CUPS PPDs will be used. To overwrite these global settings for individual printers simply add them subsequently to papd.conf and assign different settings.
If present, this flag enables a hack to translate line endings originating from pre Mac OS X LaserWriter drivers to let
recognize foomatic PPD options set in the printer dialog. Attention: Use with caution since this might corrupt binary print jobs!
This specifies the operator name, for lpd spooling.
Allows specification of Appletalk addresses. Usually not needed.
pd=(path to ppd file)
Specifies a particular PPD (printer description file) to associate with the selected printer.
pr=(lpd/CUPS printer name or pipe command)
printer that this is spooled to.
Unless CUPS support has been compiled in (which is default from Netatalk 2.0 on) one simply defines the lpd queue in question by setting the
parameter to the queue name, in the following example "ps". If no
parameter is set, the default printer will be used.
Example. papd.conf System V printing system examples
The first spooler is known by the AppleTalk name Mac Printer Spooler, and uses a PPD file located in
/usr/share/lib/ppd. In addition, the user mcs will be the owner of all jobs that are spooled. The second spooler is known as HP Printer and all options are the default.
Mac Printer Spooler:\
An alternative to the technique outlined above is to direct papd's output via a pipe into another program. Using this mechanism almost all printing systems can be driven.
Example. papd.conf examples using pipes
The first spooler is known as HP 8100. It pipes the print job to
for printing. PSSP authenticated printing is enabled, as is CAP-style authenticated printing. Both methods support guest and cleartext authentication as specified by the 'am' option. The PPD used is
Starting with Netatalk 2.0 direct CUPS integration is available. In this case, defining only a queue name as
parameter won't invoke the SysV lpd daemon but uses CUPS instead. Unless a specific PPD has been assigned using the
switch, the PPD configured in CUPS will be used by
There exists one special share named "cupsautoadd". If this is present as the first entry then all available CUPS queues will be served automagically using the parameters assigned to this global share. But subsequent printer definitions can be used to override these global settings for individual spoolers.
Example. papd.conf CUPS examples
The first entry sets up automatic sharing of all CUPS printers. All those shares appear in the zone "1st floor" and since no additional settings have been made, they use the CUPS printer name as NBP name and use the PPD configured in CUPS. The second entry defines different settings for one single CUPS printer. It's NBP name is differing from the printer's name and the registration happens in another zone.
Boss' LaserWriter@2nd floor:\