1HYLAFAX-CONFIG(5F)                                          HYLAFAX-CONFIG(5F)
2
3
4

NAME

6       config - HylaFAX configuration database
7

DESCRIPTION

9       HylaFAX  uses  a  configuration file for the central queueing agent and
10       for each facsimile modem attached to a machine.   These  files  contain
11       information about the modems and about how the HylaFAX server processes
12       that service these modem should operate.  Configuration files  are  lo‐
13       cated in the etc subdirectory.  The configuration file for the faxq(8C)
14       program is named config.  The per-modem configuration files used by the
15       faxgetty(8C),  faxsend(8C), and pagesend(8C) programs have names of the
16       form config.devid, where devid is an identifier derived from  the  name
17       of  the  modem's device file; for example ttym2 for /dev/ttym2, term_10
18       for /dev/term/10.
19
20       Configuration files have a simple format and  are  entirely  ASCII.   A
21       configuration parameter is of the form
22            tag: value
23       where a tag identifies a parameter and a value is either a string, num‐
24       ber, or boolean value.  Comments are introduced by the ``#''  character
25       and  extend  to  the end of the line.  String values start at the first
26       non-blank character after the ``:'' and  continue  to  the  first  non-
27       whitespace  character  or,  if whitespace is to be included, may be en‐
28       closed in quote marks (``"'').  String values enclosed in  quote  marks
29       may  also use the standard C programming conventions for specifying es‐
30       cape codes; e.g. ``\n'' for a newline character and ``\xxx'' for an oc‐
31       tal value.  Numeric values are specified according to the C programming
32       conventions (leading ``0x'' for hex, leading ``0'' for octal, otherwise
33       decimal),  except  for  a  few  parameters, such as RecvFileMode, whose
34       value is interpreted strictly as an octal number and  PageChopThreshold
35       whose  value is interpreted strictly as a floating point number.  Bool‐
36       ean values are case insensitive.  For a true value, either  ``Yes''  or
37       ``On'' should be used.  For a false value, use ``No'' or ``Off''.
38
39       The  following  table  itemizes the tags and the expected type of their
40       value.  The first part lists items specific to the  operation  of  each
41       server, while the second part has items related to the servicing of the
42       modem.  Parameters marked with a ¹ are used only by the HylaFAX  sched‐
43       uler  process and should appear only in the file named config.  Parame‐
44       ters marked with a ² are used by both the scheduler and the  per-device
45       applications  and  so  should  appear  in all appropriate configuration
46       files (i.e.  config and any per-device files that make sense).  Parame‐
47       ters  not  otherwise marked should appear only in per-device configura‐
48       tion files.  More detailed information about each item is given follow‐
49       ing the table.
50       Tag                           Type       Default          Description
51       AdaptiveAnswer                boolean    No               enable adaptive answer of inbound calls
52       AdminGroup                    string     faxadmin         System user group for administration (if PAM enabled)
53       AllowIgnoreModemBusy¹         boolean    No               honor job requests to ignore modem busy status
54       AnswerRotary                  string     Any              alternatives for answering calls
55       AnswerBias                    integer    -                bias to apply to successful rotary answer
56       AreaCode²                     string     -                local area code
57       AuditHook¹                    string     -                command to run for faxq event auditing
58       BadPageHandlingMethod         string     RTN-SAVE         bad page received handling method
59       BatchLogs¹                    boolean    Yes              keep all session logs of a batch in a single log
60       CallIDAnswerLength            integer    -                answer call when CallIDPattern received
61       CallIDDisplay                 boolean    No               display match in modem status
62       CallIDLabel                   string     -                label to use in presentation of the match
63       CallIDPattern                 string     -                call identification pattern string
64       CallIDRecord                  boolean    Yes              record match in recvq image file
65       CallIDType                    string     -                type identifier for the CallIDPattern match
66       CIDName                       string     -                equivalent to CallIDPattern (2)
67       CIDNameAnswerLength           integer    0                equivalent to CallIDAnswerLength (2)
68       CIDNumber                     string     -                equivalent to CallIDPattern (1)
69       CIDNumberAnswerLength         integer    0                equivalent to CallIDAnswerLength (1)
70       ClocalAsRoot                  boolean    No               set CLOCAL using root UID
71       ContCoverCmd¹                 string     bin/mkcover      continuation cover page generation program
72       ContCoverPage¹                string     -                continuation cover page template filename
73       CountryCode²                  string     -                local country code
74       DestControls¹                 obsolete   -                Obsoleted by JobControl
75       DeviceMode                    octal      0600             protection mode to use for modem device
76       DialStringRules²              string     -                dial string rules file
77       DistinctiveRings              string     -                configuration for distinctive ring cadences
78       DRingOff                      string     -                distinctive ring ``off'' cadence indicator
79       DRingOn                       string     -                distinctive ring ``on'' cadence indicator
80       DynamicConfig                 string     -                program for dynamic receive configuration
81       EGettyArgs                    string     -                arguments passed to external getty program
82       FAXNumber                     string     -                facsimile modem phone number
83       FaxRcvdCmd                    string     bin/faxrcvd      notification program for received facsimile
84       GettyArgs                     string     -                arguments passed to getty program
85       Include²                      string     -                include another config file
86       InternationalPrefix²          string     -                dialing prefix for international calls
87       JobControlCmd¹                string     -                job control command
88       JobReqBusy                    integer    180              requeue interval for BUSY dial result
89       JobReqDataConn                integer    300              requeue interval for data connection dial result
90       JobReqNoAnswer                integer    300              requeue interval for NO ANSWER dial result
91       JobReqNoCarrier               integer    300              requeue interval for NO CARRIER dial result
92       JobReqNoFCon                  integer    300              requeue interval for carrier without +FCON dial result
93       JobReqOther²                  integer    300              requeue interval for ``other'' problems
94       JobReqProto                   integer    60               requeue interval after fax protocol error
95       JobRetryBusy                  integer    -                number of retries for BUSY dial result
96       JobRetryDataConn              integer    -                number of retries for data connection dial result
97       JobRetryNoAnswer              integer    -                number of retries for NO ANSWER dial result
98       JobRetryNoCarrier             integer    1                number of retries for NO CARRIER dial result
99       JobRetryNoFCon                integer    -                number of retries for carrier without +FCON dial result
100       JobRetryOther                 integer    -                number of retries for ``other'' problems
101       LockDataCalls                 boolean    Yes              lock modem for the duration of an inbound data call
102       LockVoiceCalls                boolean    Yes              lock modem for the duration of an inbound voice call
103       LogCalls                      boolean    Yes              Log all incoming calls as CALL records in xferfaxlog
104       LogFacility²                  string     daemon           syslog facility name for ServerTracing messages
105       LogFileMode                   octal      0600             protection mode to use for session log files
106       LogRecv                       boolean    Yes              Log recieved faxes as RECV records in xferfaxlog
107       LogSend                       boolean    Yes              Log sent faxes as SEND records in xferfaxlog
108       LocalIdentifier               string     -                local station identification string
109       LongDistancePrefix            string     -                dialing prefix for long distance calls
110       MaxBatchJobs¹                 integer    64               max jobs in a batch
111       MaxConcurrentCalls¹           integer    1                max concurrent jobs to process for a destination
112       MaxConcurrentPreps¹           integer    1                maximum number of simultaneous job preparations
113       MaxConsecutiveBadLines        integer    5                max consecutive bad rows for OK page quality
114       MaxDials¹                     integer    12               max phone calls to make to transmit a job
115       MaxProxyJobs¹                 integer    64               max number of concurrent proxy jobs
116       MaxRecvPages                  integer    unlimited        max pages to permit in a receive
117       MaxSendPages¹                 integer    unlimited        max pages to permit in a send
118       MaxSetupAttempts              integer    2                max attempts to initialize a modem
119       MaxTraversal¹                 integer    256              max traversal into queue for batching
120       MaxTries¹                     integer    3                max attempts to transmit a job
121       MinAcceptedLineCount          integer    10               min number of rows for OK page quality
122       MissedPageHandlingMethod      string     RTN              missed page received handling method
123       ModemGroup¹                   string     -                define a name for a set of modems
124       ModemPriority                 integer    255              scheduling priority for outbound jobs
125       ModemReadyState               string     R                ``ready state'' sent by faxgetty
126       ModemRingResponse             string     -                command to respond after hearing RING
127       ModemRingsBeforeResponse      integer    0                the number of rings before ModemRingResponse
128       NoAnswerVoice                 boolean    false            disable the answering of voice-indicated calls
129       NoCarrierRetrys               integer    -                Deprecated - See JobRetryNoCarrier
130       NotifyCmd¹                    string     bin/notify       user notification program
131       PageChop¹                     string     last             control automatic truncation of trailing whitespace
132       PageChopThreshold¹            float      3.0              whitespace truncation threshold (inches)
133       PCL2FaxCmd¹                   string     bin/pcl2fax      PCL RIP command script
134       PercentGoodLines              integer    95               percentage of good rows for OK page quality
135       PollLockPokeModem             boolean    false            check on modem every time the lock is polled
136       PollLockWait²                 integer    30               polling interval for lockfile presence/removal (secs)
137       PollModemWait                 integer    30               polling interval when in ``modem wait'' state (secs)
138       PollRcvdCmd                   string     bin/pollrcvd     delivery program for facsimile received by polling
139       PostScriptTimeout¹            integer    300              timeout on POSTSCRIPT interpreter runs (secs)
140       PriorityScheduling            boolean    see below        use available priority job scheduling mechanism
141       PS2FaxCmd¹                    string     bin/ps2fax       POSTSCRIPT RIP command script
142       QualifyCID                    obsolete   -                See DynamicConfig and RejectCall for rejecting calls
143       QualifyPWD                    string     -                file of PWD patterns for qualifying senders
144       QualifyTSI                    string     -                file of TSI patterns for qualifying senders
145       RecvDataFormat                string     adaptive         format for received facsimile data
146       RecvFileMode                  octal      0600             protection mode to use for received facsimile files
147       RejectCall                    boolean    false            Reject the current call
148       RingData                      string     -                distinctive ring data call identifier
149       RingExtended                  string     -                extended ring message identifier
150       RingFax                       string     -                distinctive ring fax call identifier
151       RingsBeforeAnswer             integer    0                rings to wait before answering phone
152       RingTimeout                   integer    6000             timeout in ms after RING before reset
153       RingVoice                     string     -                distinctive ring voice call identifier
154       RTNHandlingMethod             string     Retransmit-IgnoreRTN signal handling method
155       SaveUnconfirmedPages          boolean    true             save or delete unconfirmed pages
156       SendFaxCmd¹                   string     bin/faxsend      fax transmit command script
157       SendPageCmd¹                  string     bin/pagesend     pager transmit command script
158       SendUUCPCmd¹                  string     bin/uucpsend     UUCP transmit command script
159       ServerTracing²                integer    1                non-session server tracing
160       SessionTracing²               integer    0xFFF            send and receive session tracing
161       ShareCallFailures²            string     none             which call failures should be shared
162       SpeakerVolume                 string     Quiet            volume level for modem speaker
163       StaggerCalls¹                 integer    0                time to delay between starting outbound calls
164       TagLineFont                   string     -                tag line font filename
165       TagLineFormat                 string     see below        tag line format string
166       TagLineLocale                 string     see below        tag line format locale
167       TIFF2FaxCmd²                  string     bin/tiff2fax     TIFF converter command script
168       TimeOfDay¹                    string     Any              default time-of-day restrictions
169       TSIRecvdCmd                   string     -                program executed after TSI receipt, can drop calls
170       Unblock¹                      string     -                force faxq to unblock specified destination
171       Use2D¹                        boolean    Yes              restrict/permit use of 2D-encoded fax data
172       UseJobTSI                     boolean    No               use job-specified TSI instead of LocalIdentifier
173       UseJobTagLine                 boolean    Yes              Allow use of job-specified Tagline instead of TagLineFormat
174       UUCPLockMode²                 octal      0600             protection mode for UUCP lock files
175       UUCPLockDir²                  string     see below        UUCP lockfile directory
176       UUCPLockTimeout²              integer    30               time before removing stale UUCP lockfile
177       UUCPLockType²                 string     see below        UUCP lockfile type
178       VGettyArgs                    string     -                arguments passed to voice getty program
179       WedgedCmd¹                    string     bin/wedged       program to run when modem is wedged
180       ModemAnswerCmd                string     ATA              command for answering phone
181       ModemAnswerAgainCmd           string     <delay:50>ATA    command for answer recovery
182       ModemAnswerDataBeginCmd       string     -                command for start of answered data call
183       ModemAnswerDataCmd            string     ATA              command for answering data call
184       ModemAnswerDialCmd            string     ATA              command for answering dialed call
185       ModemAnswerFaxBeginCmd        string     -                command for start of answered fax call
186       ModemAnswerFaxCmd             string     ATA              command for answering fax call
187       ModemAnswerResponseTimeout    integer    180000           answer command timeout (ms)
188       ModemAnswerVoiceBeginCmd      string     -                command for start of answered voice call
189       ModemAnswerVoiceCmd           string     ATA              command for answering voice call
190       ModemATCmdDelay               integer    0                delay before sending modem an AT cmd (ms)
191       ModemBaudRateDelay            integer    10               delay (ms) after setting baud rate
192       ModemCEDCmd                   string     ATA              command to signal CED and start V.21 HDLC transmit
193       ModemClassQueryCmd            string     AT+FCLASS=?      command for querying modem services
194       ModemCNGCmd                   string     ATD              command to signal CNG and listen for V.21 HDLC
195       ModemCommaPauseTimeCmd        string     ATS8=2           command for setting time to pause for ``,'' in dialing string
196       ModemDialCmd                  string     ATDT%s           command for dialing (%s for number to dial)
197       ModemDialResponseTimeout      integer    180000           dialing command timeout (ms)
198       ModemDoPhaseCDebug            boolean    No               query modem responses during Phase C transmit
199       ModemDTRDropDelay             integer    75               delay (ms) between DTR OFF and DTR ON
200       ModemEchoOffCmd               string     ATE0             command for disabling command echo
201       ModemFlowControl              string     XONXOFF          DTE-DCE flow control scheme
202       ModemFrameFillOrder           string     LSB2MSB          bit order for HDLC frames
203       ModemHardFlowCmd              string     -                command for setting hardware flow control between DTE and DCE
204       ModemMinSpeed                 string     2400             minimum acceptable transmit speed
205       ModemMfrQueryCmd              string     -                command for querying modem manufacturer
206       ModemModelQueryCmd            string     -                command for querying modem model
207       ModemNoAutoAnswerCmd          string     ATS0=0           command for disabling auto-answer
208       ModemNoAutoAnswerCmdDelay     integer    0                time, in ms, to pause after a disabling auto-answer
209       ModemNoFlowCmd                string     -                command for disabling hardware flow control between DTE and DCE
210       ModemOnHookCmd                string     ATH0             command for placing phone ``on hook''
211       ModemPageDoneTimeout          integer    180000           page send/receive timeout (ms)
212       ModemPageStartTimeout         integer    180000           page send/receive timeout (ms)
213       ModemRaiseATCommands          boolean    Yes              raise AT commands in configuration to upper-case
214       ModemRate                     integer    19200            baud rate to use for DCE-DTE communication
215       ModemReadyCmds                string     -                additional final commands when resetting modem
216       ModemRecvFillOrder            string     see below        bit order for received facsimile data
217       ModemRecvSuccessCmd           string     -                command to send after a successful reception
218       ModemResetCmds                string     -                additional commands when resetting modem
219       ModemResetDelay               integer    2600             delay (ms) after placing DTR ON
220       ModemResultCodesCmd           string     ATQ0             command for enabling result codes
221       ModemRevQueryCmd              string     see below        command for querying modem firmware revision
222       ModemSecondAnswerCmd          string     -                command to restart answer process
223       ModemSendBeginCmd             string     -                command to send on establishing carrier
224       ModemSendFillOrder            string     LSB2MSB          bit order for sending facsimile data
225       ModemSetOriginCmd             string     -                command to set call origin information
226       ModemSetVolumeCmd             string     see below        commands for setting modem speaker volume level
227       ModemSetupAACmd               string     -                command for setting up adaptive answer
228       ModemSetupDCDCmd              string     -                command for setting up DCD handling
229       ModemSetupDTRCmd              string     -                command for setting up DTR handling
230       ModemSoftFlowCmd              string     -                command for setting software flow control between DTE and DCE
231       ModemSoftResetCmd             string     ATZ              command for doing a soft reset
232       ModemSoftResetCmdDelay        integer    3000             time, in ms, to pause after a soft reset
233       ModemSoftRTFCC                boolean    Yes              enable software-driven real-time fax compression conversion
234       ModemType                     string     see below        modem type
235       ModemVerboseResultsCmd        string     ATV1             command for enabling verbose result codes
236       ModemWaitForConnect           boolean    No               force server to wait for ``CONNECT'' response on answer
237       ModemWaitTimeCmd              string     ATS7=60          command for setting time to wait for carrier when dialing
238       FaxT1Timer                    integer    35000            CCITT T.30 T1 timer (ms)
239       FaxT2Timer                    integer    7000             CCITT T.30 T2 timer (ms)
240       FaxT4Timer                    integer    3100             CCITT T.30 T4 timer (ms)
241       Class0Cmd                     string     AT+FCLASS=0      Class 0: command to enter class 0
242       Class1Cmd                     string     AT+FCLASS=1      Class 1: command to enter class 1
243       Class1Cmd                     string     AT+FCLASS=1.0    Class 1.0: command to enter class 1
244       Class1AdaptRecvCmd            string     -                Class 1/1.0: command for adaptive reception support
245       Class10AutoFallback           boolean    Yes              Class 1.0: modem implements G3 fallback
246       Class1ColorJPEGSupport        boolean    No               Class 1/1.0: to enable color JPEG fax support
247       Class1EnableV34Cmd            string     -                Class 1/1.0: command to enable V.34-fax support
248       Class1ECMCheckFrameLength     boolean    No               Class 1/1.0: require complete ECM frame lengths
249       Class1ECMSupport              boolean    Yes              Class 1/1.0: enable T.30-A ECM support
250       Class1PersistentECM           boolean    Yes              Class 1/1.0: to continue to correct while in ECM
251       Class1ECMFrameSize            integer    256              Class 1/1.0: image frame size in ECM protocol
252       Class1ExtendedRes             boolean    -                Class 1/1.0: enable extended resolution support
253       Class1HasRHConnectBug         boolean    No               Class 1/1.0: modem can report CONNECT incorrectly
254       Class1HasRMHookIndication     boolean    Yes              Class 1/1.0: modem reports ERROR correctly
255       Class1HFLOCmd                 string     -                Class 1/1.0: command to set hardware flow control
256       Class1FrameOverhead           integer    4                Class 1/1.0: extra bytes in a received HDLC frame
257       Class1GreyJPEGSupport         boolean    No               Class 1/1.0: to enable grey JPEG fax support
258       Class1HookSensitivity         integer    0                Class 1/1.0: times to ignore on-hook detection
259       Class1JBIGSupport             string     see below        Class 1/1.0: to enable monochrome JBIG fax support
260       Class1MRSupport               boolean    Yes              Class 1/1.0: enable 2-D MR support
261       Class1MMRSupport              boolean    Yes              Class 1/1.0: enable 2-D MMR support
262       Class1NFLOCmd                 string     -                Class 1/1.0: command to set no flow control
263       Class1PageLengthSupport       integer    7                Class 1/1.0: coded value for modem page length support
264       Class1PageWidthSupport        integer    7                Class 1/1.0: coded value for modem page width support
265       Class1RecvAbortOK             integer    200              Class 1/1.0: max wait (ms) for ``OK'' after recv abort
266       Class1RecvIdentTimer          integer    40000            Class 1/1.0: max wait (ms) for initial ident frame
267       Class1RestrictPoorDestinations¹          integer          0Class 1/1.0: restrict features for destinations with poor quality
268       Class1RestrictPoorSenders     integer    0                Class 1/1.0: restrict features for senders with poor quality
269       Class1RMPersistence           integer    2                Class 1/1.0: times to attempt high-speed carrier recv
270       Class1SFLOCmd                 string     -                Class 1/1.0: command to set software flow control
271       Class1PPMWaitCmd              string     AT+FTS=7         Class 1/1.0: command to stop and wait before PPM
272       Class1ResponseWaitCmd         string     -                Class 1/1.0: command to wait before TCF response
273       Class1Resolutions             integer    0x7F             Class 1/1.0: bitmap of supported resolutions
274       Class1RMQueryCmd              string     AT+FRM=?         Class 1/1.0: command to query modem data reception rates
275       Class1TCFWaitCmd              string     AT+FTS=7         Class 1/1.0: command to stop and wait before TCF
276       Class1TMQueryCmd              string     AT+FTM=?         Class 1/1.0: command to query modem data transmission rates
277       Class1EOPWaitCmd              string     AT+FTS=9         Class 1/1.0: command to stop and wait before EOP
278       Class1ModemHasDLEBug          boolean    No               Class 1/1.0: modem fails to double DLE in V.21
279       Class1MsgRecvHackCmd          string     ""               Class 1/1.0: command to avoid +FCERROR before image data
280       Class1SSLFaxCert              string     etc/ssl.pem      Class 1/1.0: PEM certificate file for SSL Fax
281       Class1SSLFaxClientTimeout     integer    5000             Class 1/1.0: timeout waiting for client connection
282       Class1SSLFaxInfo              string     -                Class 1/1.0: hostname and port number for SSL Fax
283       Class1SSLFaxSupport           boolean    Yes              Class 1/1.0: support for SSL Fax
284       Class1SSLFaxServerTimeout     integer    2000             Class 1/1.0: timeout waiting for server connection
285       Class1TCFRecvHackCmd          string     ""               Class 1/1.0: command to avoid +FCERROR before TCF
286       Class1TCFMaxNonZero           integer    10               Class 1/1.0: max% of non-zero data in good TCF
287       Class1TCFMinRun               integer    1000             Class 1/1.0: minimum zero run in good TCF
288       Class1TCFMinRunECMMod         integer    2                Class 1/1.0: modify minimum zero run in ECM by this factor
289       Class1TCFRecvTimeout          integer    4500             Class 1/1.0: max wait (ms) for TCF
290       Class1TMConnectDelay          integer    0                Class 1/1.0: delay between +FTM CONNECT and data transmission
291       Class1SwitchingCmd            string     AT+FRS=7         Class 1/1.0: command to ensure silence after HDLC reception
292       Class1ValidateV21Frames       boolean    No               Class 1/1.0: check FCS against received frames
293       Class2Cmd                     string     AT+FCLASS=2      Class 2: command to enter class 2/2.0
294       Class2AbortCmd                string     AT+FK            Class 2: command to abort active session
295       Class2APCmd                   string     AT+FAP           Class 2: enable support for sending and receiving SUB, SEP, and PWD frames
296       Class2APQueryCmd              string     AT+FAP=?         Class 2: query capabilities for sending and receiving SUB, SEP, and PWD frames
297       Class2BORCmd                  string     AT+FBOR=0        Class 2: command to setup bit order
298       Class2BUGCmd                  string     AT+FBUG=1        Class 2: command to enable HDLC frame tracing
299       Class2CIGCmd                  string     AT+FCIG          Class 2: command to set polling identifier
300       Class2CRCmd                   string     AT+FCR=1         Class 2: command to enable receive capability
301       Class2CQCmd                   string     -                Class 2: command to setup copy quality parameters
302       Class2CQQueryCmd              string     AT+FCQ=?         Class 2: command to query modem copy quality capabilities
303       Class2DCCCmd                  string     AT+FDCC          Class 2: command to set modem capabilities
304       Class2DCCQueryCmd             string     AT+FDCC=?        Class 2: command to query modem capabilities
305       Class2DisableV17Cmd           string -   Class 2: command to disable V.17 support
306       Class2DISCmd                  string     AT+FDIS          Class 2: command to set session parameters
307       Class2DDISCmd                 string     -                Class 2: command to set session parameters before dialing
308       Class2ECMType                 string     ``2''            Class 2: ECM specification type to follow
309       Class2HexNSF                  boolean    Yes              Class 2: parse NSF strings as hex values
310       Class2HFLOCmd                 string     -                Class 2: command to set hardware flow control
311       Class2LIDCmd                  string     AT+FLID          Class 2: command to set local identifier string
312       Class2MINSPCmd                string     AT+FMINSP        Class 2: command to set minimum transmit speed
313       Class2NFLOCmd                 string     -                Class 2: command to set no flow control
314       Class2PACmd                   string     AT+FPA           Class 2: set polling address string
315       Class2PHCTOCmd                string     AT+FPHCTO=30     Class 2: command to set Phase C timeout parameter
316       Class2PTSCmd                  string     AT+FPTS          Class 2: command to set received page status
317       Class2PWCmd                   string     AT+FPW           Class 2: set password string
318       Class2RecvDataTrigger         string     ``\21''          Class 2: character to send to trigger recv
319       Class2RELCmd                  string     -                Class 2: command to enable byte-aligned EOL codes
320       Class2SACmd                   string     AT+FSA           Class 2: set destination subaddress string
321       Class2SendRTC                 boolean    No               Class 2: append RTC to page data on transmit
322       Class2SFLOCmd                 string     -                Class 2: command to set software flow control
323       Class2SPLCmd                  string     AT+FSPL          Class 2: command to set polling request
324       Class2TBCCmd                  string     AT+FTBC=0        Class 2: command to enable stream mode
325       Class2UseLineCount            boolean    No               Class 2: use the line count from the firmware decoder
326       Class2UseHex                  boolean    No               Class 2: parse capabilities strings as hex values
327       Class2XmitWaitForXON          boolean    Yes              Class 2: wait for XON before sending facsimile data
328       Class2Cmd                     string     AT+FCLASS=2.0    Class 2.0: command to enter class 2/2.0
329       Class2AbortCmd                string     AT+FKS           Class 2.0: command to abort active session
330       Class2APCmd                   string     AT+FAP           Class 2.0: enable support for sending and receiving SUB, SEP, and PWD frames
331       Class2APQueryCmd              string     AT+FAP=?         Class 2.0: query capabilities for sending and receiving SUB, SEP, and PWD frames
332       Class2BORCmd                  string     AT+FBO=0         Class 2.0: command to setup bit order
333       Class2BUGCmd                  string     AT+FBU=1         Class 2.0: command to enable HDLC frame tracing
334       Class2CIGCmd                  string     AT+FPI           Class 2.0: command to set polling identifier
335       Class2CRCmd                   string     AT+FCR=1         Class 2.0: command to enable receive capability
336       Class2CQCmd                   string     -                Class 2.0: command to setup copy quality parameters
337       Class2CQQueryCmd              string     AT+FCQ=?         Class 2.0: command to query modem copy quality capabilities
338       Class2DCCCmd                  string     AT+FCC           Class 2.0: command to set modem capabilities
339       Class2DCCQueryCmd             string     AT+FCC=?         Class 2.0: command to query modem capabilities
340       Class2DisableV17Cmd           string -   Class 2.0: command to disable V.17 support
341       Class2DisableV34Cmd           string -   Class 2.0: command to disable V.34 support
342       Class2DISCmd                  string     AT+FIS           Class 2.0: command to set session parameters
343       Class2ECMType                 string     ``2.0''          Class 2.0: ECM specification type to follow
344       Class2HexNSF                  boolean    Yes              Class 2.0: parse NSF strings as hex values
345       Class2HFLOCmd                 string     AT+FLO=2         Class 2.0: command to set hardware flow control
346       Class2JBIGSupport             string     see below        Class 2.0: to enable monochrome JBIG fax support
347       Class2JPEGSupport             boolean    No               Class 2.0: use modem JPEG support
348       Class2LIDCmd                  string     AT+FLI           Class 2.0: command to set local identifier string
349       Class2MINSPCmd                string     AT+FMS           Class 2.0: command to set minimum transmit speed
350       Class2NFLOCmd                 string     AT+FLO=0         Class 2.0: command to set no flow control
351       Class2NRCmd                   string     AT+FNR=1,1,1,1   Class 2.0: command to set negotiation message reporting
352       Class2PACmd     string        AT+FPA     Class 2.0: set polling address string
353       Class2PHCTOCmd                string     AT+FCT=30        Class 2.0: command to set Phase C timeout parameter
354       Class2PIECmd                  string     AT+FIE=0         Class 2.0: command to set procedure interrupt handling
355       Class2PWCmd     string        AT+FPW     Class 2.0: set password string
356       Class2PTSCmd                  string     AT+FPS           Class 2.0: command to set received page status
357       Class2PTSQueryCmd             string     AT+FPS?          Class 2.0: command to query received page status
358       Class2RecvDataTrigger         string     ``\22''          Class 2.0: character to send to trigger recv
359       Class2RELCmd                  string     -                Class 2.0: command to enable byte-aligned EOL codes
360       Class2RTFCC                   boolean    No               Class 2.0: enable real-time fax compression conversion
361       Class2SACmd     string        AT+FSA     Class 2.0: set destination subaddress string
362       Class2SendRTC                 boolean    No               Class 2.0: append RTC to page data on transmit
363       Class2SFLOCmd                 string     AT+FLO=1         Class 2.0: command to set software flow control
364       Class2SPLCmd                  string     AT+FSP           Class 2.0: command to set polling request
365       Class2TBCCmd                  string     AT+FPP=0         Class 2.0: command to enable stream mode
366       Class2UseLineCount            boolean    No               Class 2.0: use the line count from the firmware decoder
367       Class2UseHex                  boolean    No               Class 2.0: parse capabilities strings as hex values
368       PagerSetupCmds                string     -                commands for setting up modem for a pager call
369       PagerMaxMsgLength             integer    128              max length of a text message
370       IXOService                    string     ``PG''           IXO: service identification string
371       IXODeviceID                   string     ``1''            IXO: device identification string
372       IXOMaxUnknown                 integer    3                IXO and UCP: max unknown responses before abort
373       IXOIDProbe                    integer    2                IXO: time between sending \r during ID sequence (secs)
374       IXOIDTimeout                  integer    20               IXO: max time to wait for ID= response (secs)
375       IXOLoginRetries               integer    3                IXO: max attempts to login
376       IXOLoginTimeout               integer    15               IXO: max time to complete login (secs)
377       IXOGATimeout                  integer    30               IXO: max time to wait for Go-Ahead response (secs)
378       IXOXmitRetries                integer    3                IXO and UCP: max retries to send text msg block
379       IXOXmitTimeout                integer    15               IXO and UCP: max time to transmit text msg block
380       IXOAckTimeout                 integer    30               IXO: max time to wait for msg block ack (secs)
381

SERVER-ORIENTED CONFIGURATION PARAMETERS

383       These  configuration parameters affect the general operation of the fax
384       server.
385
386       AdaptiveAnswer
387              Control whether or not an adaptive answering  strategy  is  used
388              whereby  an incoming call is answered in multiple ways according
389              to the list specified in the AnswerRotary parameter.  For  exam‐
390              ple, if adaptive answering is enabled and AnswerRotary specifies
391              ``fax data'', then an incoming call will first  be  answered  as
392              fax using ModemAnswerFaxCmd and then, if that fails, as data us‐
393              ing ModemAnswerDataCmd.  If the adaptive answer strategy is  not
394              enabled,  then calls are answered using the appropriate ModemAn‐
395              swer*Cmd parameter (normally ModemAnswerCmd for unattended oper‐
396              ation).   Note that the adaptive answer strategy depends on many
397              factors that limit its  usefulness.   When  calls  are  answered
398              first  as  fax, it typically only works with a Class 1 modem be‐
399              cause it is important that the sequence of operations related to
400              answering as fax be completed in a short enough time that a sub‐
401              sequent answer for data be done before the caller times out  and
402              hangs  up  the  telephone  (for this reason Class1RecvIdentTimer
403              should be set to a  value  that  is  shorter  than  FaxT1Timer.)
404              Also,  note  that  it is sometimes necessary to arrange that the
405              phone be placed on-hook between  successive  answers;  this  can
406              typically  be  done  by inserting the appropriate command at the
407              start of the second and subsequent ModemAnswer*Cmds.
408
409       AdminGroup
410              Tells PAM what user group  is  allowed  to  administer  the  fax
411              server.  Only useful if the server is compiled with PAM enabled.
412
413       AllowIgnoreModemBusy¹
414              Whether or not to honor job requests to ignore modem busy status
415              when allocating jobs to a modem.  The intended use for this fea‐
416              ture  is to allow configurations whereby a DynamicConfig program
417              can send a fax to an incoming caller (contrary to T.30  protocol
418              for sending or polling).
419
420       AnswerRotary
421              The  sequence of answering techniques the server should ``rotate
422              through'' when answer incoming calls.  Answering techniques are:
423              Name    Description
424              fax     answer a fax call
425              data    answer a data call
426              voice   answer a voice call
427              extern  use the vgetty application to answer a call
428              any     answer a call of any/unknown type
429              When a call is not answered successfully,  the  server  advances
430              the  rotary to the next specified answering technique.  If Adap‐
431              tiveAnswer is enabled, the server will  try  all  the  answering
432              techniques for each incoming call.  Otherwise, the rotary is ad‐
433              vanced between unsuccessful phone calls.  For example, if  Adap‐
434              tiveAnswer  is  disabled  and AnswerRotary is ``fax data'', then
435              the calls will initially be answered as fax until the first call
436              is received that does not appear to be from a fax machine; after
437              that calls will be answered as if they were from  a  data  modem
438              until  the  next  unsuccessful  call;  after which they will one
439              again be answered as  fax.   Only  the  first  three  techniques
440              listed  are  used;  any  additional ones are (silently) ignored.
441              See also AnswerBias.
442
443       AnswerBias
444              The index into the AnswerRotary list that the server should  ro‐
445              tate  the  list  to  after  each successful incoming phone call.
446              List indices are numbered starting at zero.  For example, if An‐
447              swerRotary  is ``fax data'' and AnswerBias is 1, then after each
448              successful inbound call, the next call will be answered as data.
449
450       AreaCode²
451              The local area code in which the facsimile modem resides.   This
452              value  is passed to the dial string rules that are used, for ex‐
453              ample, to formulate canonical phone numbers for dialing (see Di‐
454              alStringRules below.)
455
456       AuditHook¹
457              Specifies  a program command and an interest specification indi‐
458              cating which events as described in faxwatch(8C) should  trigger
459              the execution of the program.  For example, this configuration:
460
461                  AuditHook: "bin/hook: J*S*M*R*"
462
463              would cause bin/hook to be executed upon every event.  The argu‐
464              ments passed to  the  hook  program  are  respectively  <class>,
465              <mask>, <id>, and optionally [info] where...
466
467                  <class> = JOB | SEND | MODEM | RECV
468                  <mask>  = the specific event
469                  <id>    = id of the job/modem with which the event is associated
470                  [info]  = additional information
471
472
473       BadPageHandlingMethod
474              (Class 1/1.0 only) Specifies how to react to a bad page received
475              from the remote sender:  one  of  ``RTN'',  ``DCN'',  or  ``RTN-
476              SAVE''.
477
478              If  a page is received in non-ECM mode with unacceptable quality
479              according to PercentGoodLines or MaxConseutiveBadLines  then  it
480              can  be  somewhat difficult to inform the sender of the problem.
481              Historically, HylaFAX has assumed that  signalling  RTN  to  the
482              sender  will  accomplish  this.  However, some senders are inca‐
483              pable of retransmitting pages, and to reduce burden  they  treat
484              an  RTN signal as a receipt confirmation and proceed to the next
485              page without notifying the sending user of the potential problem
486              in  readability on the receive-end.  (The assumption there being
487              that the receiving user will notify the sending  user  if  there
488              actually is a readability problem.)
489
490              A  setting  of ``RTN'' is the historic behavior and assumes that
491              an RTN signal will be enough to get the sender to retransmit  or
492              be  otherwise informed of a potential readability problem on the
493              receive-end.  The previously-received page data is marked to  be
494              overwritten by the next page data received from the sender.
495
496              A  setting  of ``DCN'' tells HylaFAX to transmit a DCN signal in
497              response to the post-page message  and  should  trigger  a  call
498              abortion  by the sender.  This should clearly indicate a problem
499              in page readability to the sender, although the receipt  of  any
500              following pages in a later call cannot be guaranteed.
501
502              A setting of ``RTN-SAVE'' more closely approximates the behavior
503              of other fax receivers (especially fax machines).  It causes Hy‐
504              laFAX  to  send  the  RTN signal but it saves the previously re‐
505              ceived page data and places the next transmitted  page  data  in
506              another page.  This is the default setting.  However, this could
507              result in multiple copies of the same page image being saved  in
508              the  same  file - if the sender does indeed retransmit the unac‐
509              ceptable pages during the same call.
510
511       BatchLogs¹
512              When sending or receiving multiple documents (denoted  by  EOM),
513              this  value determines if the session logs span the entire batch
514              or, if set to no, only contain a single document.
515
516       CallIDPattern
517              A string that identifies the caller's identity in any call iden‐
518              tification  messages provided by the modem (such as Caller*ID or
519              DNIS/DID).  The specified string is compared against any  unrec‐
520              ognized  status messages received from the modem before ModemAn‐
521              swerCmd is sent to the modem.  If there is a match, then the re‐
522              mainder  of  the  message  is returned as CallIDn where n corre‐
523              sponds to the n'th instance that this CallIDPattern is from  the
524              top in the modem configuration file.  For example, for the ZyXEL
525              U-1496 this parameter would be set to
526              CallIDPattern: ``CALLER NAME: '' (note the trailing space).
527              If more than one message matches  between  instances  of  "RING"
528              messages, then the message remainders are concatenated.
529
530              The  special CallID value of "SHIELDED_DTMF" is used in conjunc‐
531              tion with ModemRingResponse and CallIDAnswerLength.  After  exe‐
532              cuting ModemRingResponse, HylaFAX will expect DTMF data (usually
533              DLE-shielded) for CallIDn until CallIDAnswerLength  is  reached.
534              Note  that if the modem is in voice mode to hear these DTMF dig‐
535              its, then it must be returned to fax mode in the ModemAnswerCmd.
536              In order to prevent this feature from losing incoming fax calls,
537              if fax sender CNG is detected while waiting for DTMF or  if  ten
538              seconds  elapse  without  sufficient DTMF then the remaining ex‐
539              pected digits will be populated by  whitespace,  triggering  fax
540              answering.
541
542              For  example, the following settings will cause HylaFAX to enter
543              voice mode and go off-hook when a RING  is  detected.   It  will
544              then  expect four DTMF digits (presumably for routing), and then
545              it will pause for 100 ms before returning to fax  mode  and  an‐
546              swering the call.
547
548                ModemRingResponse:     AT+FCLASS=8;H1
549                CallIDPattern:         SHIELDED_DTMF
550                CallIDAnswerLength:    4
551                ModemAnswerCmd:        <delay:100>AT+FCLASS=1;A
552
553              For  modems  that  do  not support AT+FCLASS=8 (such as some USR
554              modems) this may be an appropriate equivalent:
555
556                ModemRingResponse:      "AT#CLS=8\nAT#VLS=4\nATA"
557                CallIDPattern:          SHIELDED_DTMF
558                CallIDAnswerLength:     4
559                ModemAnswerCmd:         "<delay:100>AT+FCLASS=1\nATA"
560
561              Multiple entries of CallIDPattern are used together in one modem
562              configuration  file  in  order  to  capture  multiple CallID re‐
563              sponses.  For example,  the  following  settings  would  capture
564              "NDID"  responses  from  the  modem as CallID1, "NMBR" responses
565              from the modem as CallID2, "NAME" responses as CallID3,  and  it
566              would  trigger  ModemAnswerCmd  whenever CallID1 or CallID2 were
567              longer than 7 or 10 characters, respectively.
568
569                CallIDPattern:         "NDID="
570                CallIDAnswerLength:    7
571                CallIDPattern:         "NMBR="
572                CallIDAnswerLength:    10
573                CallIDPattern:         "NAME="
574
575              Note that this example is only given as an example, and probably
576              would  cause  unexpected results.  Because pattern-matching ends
577              when ModemAnswerCmd is sent to the modem, if "NDID", "NMBR", and
578              "NAME"  responses  came  from  the  modem in that order, and the
579              "NDID" response was at least 7 characters  long,  then  ModemAn‐
580              swerCmd  would  be  sent  to the modem immediately following the
581              "NDID" response, and the "NMBR" and "NAME"  responses  would  be
582              ignored.   Generally  only one CallIDAnswerLength item should be
583              in a modem configuration file.
584
585              Call identification data is usually only sent once by the  telco
586              or  PBX,  and the timing of its arrival varies upon the telco or
587              PBX and the type of line.  If HylaFAX is  configured  to  answer
588              via RingsBeforeAnswer prior to the arrival of the data, then all
589              CallID values will be null.  For example, on  US  analog  lines,
590              caller-ID  data  is usually sent between RINGs 1 and 2.  In this
591              situation, RingsBeforeAnswer should be set to ``2'' or greater.
592
593       CallIDAnswerLength
594              An integer indicating the minimum number of characters in a Cal‐
595              lID  matching  the  previous  CallIDPattern  to be received when
596              ModemAnswerCmd is sent to the modem irrespective of any RingsBe‐
597              foreAnswer  value  greater than zero.  This allows the answering
598              of calls which deliver CID/DID data but not RINGs.  For example,
599              CallIDAnswerLength: ``7''
600              would cause the call to  be  answered  when  CallID2  reached  a
601              length  of seven digits.  A value of zero for CallIDAnswerLength
602              disables this feature.
603
604       CallIDDisplay
605              Whether or not to display the CallIDPattern match in  the  modem
606              status line.
607
608       CallIDLabel
609              The label to use in the presentation of any CallIDPattern match.
610              (For example, when CallIDDisplay  or  CallIDRecord  indicate  to
611              diplay or record the match.)
612
613       CallIDRecord
614              Whether or not to record the CallIDPattern match in the received
615              image file.
616
617       CallIDType
618              Identifies the type of indicator in the associated CallIDPattern
619              match.  The special type ``calling-number'' enables the faxgetty
620              process to utilize an associated entry in the info database  for
621              items  such as senderDataSent, senderDataMissed, senderConfuses‐
622              RTN, senderConfusesPIN,  senderFumblesECM,  senderHasV17Trouble,
623              and senderSkipsV29.  See hylafax-info(5F).
624
625       ClocalAsRoot
626              Control  whether operations that set the CLOCAL bit on the modem
627              device special file are done with the effective user-ID  set  to
628              the  super-user or the ``fax'' user.  By default such operations
629              are done as the fax user, except under IRIX where they are  done
630              as the super-user (because IRIX disallows manipulation of CLOCAL
631              by anyone but the super-user).
632
633       ContCoverCmd¹
634              The program to invoke to generate a continuation cover page; see
635              ContCoverPage and mkcover(8C).
636
637       ContCoverPage¹
638              A template file to use in creating continuation cover pages.  If
639              this parameter is non-null, then the server will pass the  file‐
640              name  to the command specified by ContCoverCmd to generate cover
641              pages for outbound jobs that are continued  after  protocol  er‐
642              rors.  These cover pages identify the receiver and indicate that
643              the document is a continued transmission.  If this parameter  is
644              not specified or is null, then the server will not generate con‐
645              tinuation cover pages.  The specified pathname must be  relative
646              to the top of the fax server's spooling area.
647
648       CountryCode²
649              The local country code in which the facsimile modem resides.  As
650              for AreaCode, this value is passed to the dial string rules  for
651              use  in  formulating  canonical phone numbers for dialing (among
652              other things.)
653
654       DeviceMode
655              The file protection mode that the server should set for the  mo‐
656              dem  device  file.  Note that this value is given in octal.  The
657              default value of 0600 implies that only the facsimile user (usu‐
658              ally uucp) can access the modem.  See also chmod(2).
659
660       DialStringRules²
661              The  pathname  of  the  file that holds the rules for processing
662              user-specified dial strings; c.f.  dialrules(5F).  The specified
663              pathname  must be relative to the top of the fax server's spool‐
664              ing area; e.g.  etc/dialrules.
665
666       DistinctiveRings
667              Modern distinctive ring support on  most  modems  indicates  the
668              ring   cadence   rather  than  the  older  style  of  ``RING1'',
669              ``RING2'', etc.  To  indicate  the  ring  cadence,  DRingOn  and
670              DRingOff  values  are  presented  by  the  modem to the faxgetty
671              process.   The  modem  indicates  the  entire  cadence   between
672              ``RING'' indications Like this:
673
674                RING
675                DROF=40
676                DRON=8
677                DROF=4
678                DRON=8
679                RING
680
681              The  corresponding  DistinctiveRings parameter for this ring ca‐
682              dence would be:
683
684                DistinctiveRings:  F-8-4-8
685
686              where ``F'' tells the faxgetty process that the ring cadence  is
687              for  a  facsimile  (``V'' for voice and ``D'' for data), and the
688              other values describe the ring cadence with leading  and  ending
689              DRingOff  values  ignored.  Multiple ring cadences are indicated
690              by delimiting them with commas in this fashion:
691
692                DistinctiveRings:  V-20,F-8-4-8,D-4-2-4-8
693
694
695       DRingOff
696              A string that identifies the ``off'' value  in  any  distinctive
697              ring  cadence, for example ``DROF=''.  See also DRingOn and Dis‐
698              tinctiveRings.
699
700       DRingOn
701              A string that identifies the ``on''  value  in  any  distinctive
702              ring cadence, for example ``DRON=''.  See also DRingOff and Dis‐
703              tinctiveRings.
704
705       DynamicConfig
706              The pathname of the optional program, e.g. ``etc/localid'', that
707              makes  dynamic  configuration changes, i.e., to LocalIdentifier,
708              based on device ID and  call  identification.   The  program  is
709              passed those values as the parameters ($1 = device id, $2 = Cal‐
710              lID1, $3 = CallID2, $4 = CallID3, ...), when answering an incom‐
711              ing  call.  The program can then perform local processing as de‐
712              sired to send on standard  output  the  configuration  items  to
713              change in a ``parameter:value'' format, i.e.  ``LocalIdentifier:
714              +1.800.555.1212''.  If  there  are  multiple  parameters  to  be
715              changed,  then  each item must be on its own line.  This is com‐
716              monly used to dynamically alter the local identification of sys‐
717              tems  which  use DID/DNIS, but it can also be used to allow dif‐
718              ferent modem configurations for different senders.  This program
719              can also set the RejectCall options to cause the current call to
720              be rejected instead of answered.  Note that this  file  must  be
721              marked as executable by the faxgetty process.
722
723       EGettyArgs
724              A  string that indicates whether or not the server should use an
725              an external getty application (egetty)  to  perhaps  deduce  and
726              possibly  handle  an  incoming call.  If the string value is not
727              null, then it is interpreted as a set of arguments  to  pass  to
728              egetty.   Before  supplying  the  arguments, the string is first
729              scanned for ``%''-escape sequences: any appearance of ``%l''  is
730              replaced  with  the tty name and any appearance of ``%s'' is re‐
731              placed with the serial port speed (in decimal).  Any  appearance
732              of  escaped  numbers 1 through 9 (``%1'' through ``%9'') are re‐
733              placed by the  match  to  the  corresponding  CallIDPattern,  if
734              present.   The ``%'' character can be specified with ``%%''.  If
735              the EGettyArgs parameter is not specified in  the  configuration
736              file or if the string value is null, then ``extern'' connections
737              will be rejected.  Note that in addition to the  specified  com‐
738              mand  line arguments, egetty is invoked with its standard input,
739              output, and error descriptors directed to  the  controlling  tty
740              device.
741
742              When  egetty  completes, its exit status is evaluated and is in‐
743              terpreted to indicate what, if anything, should be done with the
744              call.   An  exit  status of ``0'' indicates an unknown call type
745              and that the call should be handled as if egetty  had  not  been
746              used.   An  exit status of ``1'' indicates a data connection and
747              that the getty(8C) program should be used to handle the call  if
748              configured  (see  GettyArgs),  otherwise it will assume that the
749              call has been answered and that a data connection is established
750              and  that  it  should proceed by issuing ModemAnswerDataBeginCmd
751              (if configured) to the modem.  An exit status of ``2'' indicates
752              a  fax  connection  is established and that it should proceed by
753              issuing ModemAnswerFaxBeginCmd (if configured) to the modem.  An
754              exit  status of ``3'' indicates a voice call and that the vgetty
755              program should be used to handle the  call  if  configured  (see
756              VGettyArgs), otherwise it will assume that the call has been an‐
757              swered and that a voice connection is established  and  that  it
758              should  proceed  by issuing ModemAnswerVoiceBeginCmd (if config‐
759              ured) to the modem.  An exit status of ``4'' is considered to be
760              an  error  condition.   The session will be terminated.  An exit
761              status of ``5'' is used to indicate that egetty handled the call
762              entirely,  is not an error condition, and that the session is to
763              be considered terminated.  Exit status values of ``11'', ``12'',
764              and  ``13'' correspond to values ``1'', ``2'', and ``3'' respec‐
765              tively except that values ``11'', ``12'',  and  ``13''  indicate
766              that  the  call  has  not been answered yet with a data, fax, or
767              voice connection.  So if GettyArgs is not configured then  Mode‐
768              mAnswerDataCmd  is  first issued to the modem for an exit status
769              of ``11'', ModemAnswerFaxCmd is first issued to the modem for an
770              exit  status of ``12'', and if VGettyArgs is not configured then
771              ModemAnswerVoiceCmd is first issued to the  modem  for  an  exit
772              status of ``13''.
773
774       FAXNumber
775              The  phone  number  associated  with  the facsimile modem.  This
776              string is used to generate the Transmitter Subscriber  Identifi‐
777              cation (TSI) and Caller Subscriber Identification (CSI) informa‐
778              tion passed to remote machines—unless the LocalIdentifier param‐
779              eter  is explicitly set.  The FAXNumber is also used to name the
780              session log file where information for incoming phone  calls  is
781              recorded;  see  hylafax-log(5F).   If this phone number is not a
782              fully qualified number the values of  AreaCode  and  CountryCode
783              are used to generate the transmitted CSI and TSI.
784
785       Include²
786              Include  the  specified  config  file as if it were part of this
787              config file.
788
789       InternationalPrefix²
790              The string to use to place an international phone call.  In  the
791              United  States,  this  is ``011''.  This string is passed to the
792              dial string rules.
793
794       JobControlCmd¹
795              The command to invoke to which provides Job Control  information
796              for a job. See jobcontrol(8C).
797
798       JobReqBusy
799              The delay in seconds to wait before retrying a job whose dialing
800              attempt failed with a ``BUSY'' status result.
801
802       JobReqDataConn
803              The delay in seconds to wait before  retrying  a  facsimile  job
804              whose  dialing  attempt failed because a data modem answered the
805              phone.
806
807       JobReqNoAnswer
808              The delay in seconds to wait before retrying a job whose dialing
809              attempt failed with a ``NO ANSWER'' status result.
810
811       JobReqNoCarrier
812              The delay in seconds to wait before retrying a job whose dialing
813              attempt failed with a ``NO CARRIER'' status result.
814
815       JobReqNoFCon
816              The delay in seconds to wait before  retrying  a  facsimile  job
817              whose  dialing attempt failed because the initial facsimile pro‐
818              tocol handshake failed (i.e. no ``+FCON:'' result  was  received
819              from a Class 2/2.0 modem).
820
821       JobReqOther²
822              The  delay  in seconds to wait before retrying a job that failed
823              for a reason not already covered by one of the  JobReq*  parame‐
824              ters.
825
826       JobReqProto
827              The  delay  in  seconds  to wait before retrying a facsimile job
828              that failed because of a fax protocol error.
829
830       JobRetryBusy
831              The number of times to redial a phone number after  receiving  a
832              ``BUSY''  result  code when the number has not been successfully
833              dialed before.
834
835       JobRetryDataConn
836              The number of times to redial a phone number after  the  dialing
837              attempt  failed because a data modem answered the phone when the
838              number has not been successfully dialed before.
839
840       JobRetryNoAnswer
841              The number of times to redial a phone number after  the  dialing
842              attempt failed because of NO ANSWER when the number has not been
843              successfully dialed before.
844
845       JobRetryNoCarrier
846              The number of times to redial a phone number after  the  dialing
847              attempt  failed  because  of  NO CARRIER when the number has not
848              been successfully dialed before.  In normal  operation  the  fax
849              server  will treat this result code to mean that a facsimile mo‐
850              dem/machine did not answer the phone  and  reject  the  transmit
851              job.   This is done to avoid repeatedly dialing wrong phone num‐
852              bers and depends on the modem distinguishing between no  carrier
853              and no answer.  However, some modems are not capable of reliably
854              distinguishing between no carrier and no  answer,  or  when  in‐
855              structed  to do so do not identify a busy signal correctly.  For
856              these modems one may find it necessary to increase the value  of
857              this  parameter to compensate.  It is strongly recommended, how‐
858              ever, that this value not be set to a large number.
859
860       JobRetryOther
861              The number of times to redial a phone number after  the  dialing
862              attempt  failed  for  a reason not already covered by one of the
863              other JobRetry* parameters when the number has not been success‐
864              fully dialed before.
865
866       GettyArgs
867              A  string that indicates whether or not the server should invoke
868              the getty(8C) program in response to an  incoming  call  from  a
869              data  modem.  If the string value is not null, then it is inter‐
870              preted as a set of arguments to pass to the getty program.   Be‐
871              fore  supplying  the  arguments, the string is first scanned for
872              ``%''-escape sequences: any appearance  of  ``%l''  is  replaced
873              with  the tty name and any appearance of ``%s'' is replaced with
874              the serial port speed (in decimal).  Any appearance  of  escaped
875              numbers  1 through 9 (``%1'' through ``%9'') are replaced by the
876              match to the corresponding CallIDPattern, if present.  The ``%''
877              character can be specified with ``%%''.  If the GettyArgs param‐
878              eter is not specified in the configuration file or if the string
879              value  is  null,  then  data connections will be rejected.  Note
880              that in addition to the specified command  line  arguments,  the
881              getty  program  is  invoked with its standard input, output, and
882              error descriptors directed to the controlling tty device.
883
884       LocalIdentifier
885              The local station identification string to use when transmitting
886              TSI  and  CSI  strings  (see  FAXNumber  above).  NB: while this
887              string may contain any printable ASCII characters;  beware  that
888              CCITT  T.30  specifies  a  restricted character set and some fax
889              modems and machines may reject or  not  display   non-conforming
890              strings.   If the local identifier is not specified, a canonical
891              form of the FAXNumber is used instead.
892
893       LockDataCalls
894              Hold the UUCP lockfile during the time an inbound data  call  is
895              processed  by  the  external getty program.  If this is disabled
896              then the lockfile will be removed just before the getty  program
897              is invoked.  Note however that doing this introduces a race con‐
898              dition whereby an outbound program may sneak in and take control
899              of  the  modem after the inbound call has been accepted, but be‐
900              fore the getty program has started up  and  installed  it's  own
901              lockfile.
902
903       LockVoiceCalls
904              Hold  the  UUCP lockfile during the time an inbound data call is
905              processed by the external voice getty program.  If this is  dis‐
906              abled  then  the  lockfile will be removed just before the voice
907              getty program is invoked.  Note however that doing  this  intro‐
908              duces  a race condition whereby an outbound program may sneak in
909              and take control of the modem after the inbound  call  has  been
910              accepted,  but before the voice getty program has started up and
911              installed it's own lockfile.
912
913       LogFacility²
914              The symbolic name for the syslog(3) facility to use when logging
915              error  messages  and  informational/debugging messages requested
916              through the ServerTracing parameter.  The list of facility names
917              is  standardized;  it  can  be  found in the system include file
918              <syslog.h>; comparisons are case-insensitive.
919
920       LogCalls
921              Log all incoming calls into xferfaxlog as  CALL  records.   This
922              allows  a  quick  check of all incoming calls, regardless of fax
923              completion or not in a unified manner with other fax logs.
924
925       LogFileMode
926              The file protection mode that should be used when creating files
927              to  hold  session logs.  Note that this value is given in octal.
928              The default value of 0600 implies that the  log  files  are  not
929              generally  accessible,  which is important if sensitive informa‐
930              tion such as calling card access codes are logged.  If log files
931              are  to be publicly accessible, this value may be set, for exam‐
932              ple, to 0644.  See also chmod(2).
933
934       LogRecv
935              Log all recieved faxes into xferfaxlog as RECV records.
936
937       LogSend
938              Log all sent faxes into xferfaxlog as SEND records.
939
940       LongDistancePrefix²
941              The string to use to place a long distance phone call.   In  the
942              United States, this is ``1''.
943
944       MaxConcurrentCalls¹
945              The  default value to use for the maximum number of jobs for the
946              same destination that are processed concurrently.  Thus this pa‐
947              rameter  defines the maximum number of concurrent phone calls to
948              the same destination.  Unless all of your fax destinations  have
949              multiple  fax  lines  using  the same fax number per destination
950              then MaxConcurrentCalls is probably best left as the default  of
951              1 and exceptions should be accommodated by the JobControl mecha‐
952              nism.  However, for  high-throughput  applications  the  special
953              value  of  ``0''  may  be used; this configuration instructs the
954              server to permit limitless concurrent calls to the same destina‐
955              tion  provided  that all existing calls to that destination have
956              connected.  In this configuration if a busy  signal  is  encoun‐
957              tered  for a concurrent call then the various ``dials'' counters
958              are not incremented, and further concurrent calls are  temporar‐
959              ily stalled.
960
961       MaxConcurrentPreps¹
962              The maximum number of jobs preparations that may be run simulta‐
963              neously.  This is designed to prevent the scheduler from  initi‐
964              ating  so many job preparations that the system resources become
965              constrained in the operations.
966
967       MaxBatchJobs¹
968              The maximum number of jobs to batch together in a single call.
969
970       MaxConsecutiveBadLines
971              The maximum number of consecutive erroneous rows of  image  data
972              that  the server will receive before it deems a page to have un‐
973              acceptable copy quality.  Setting this parameter to zero  causes
974              the server to not check the quality of received facsimile.  Fac‐
975              simile received with error-correction do not have  copy  quality
976              checking performed.  See also PercentGoodLines.
977
978       MaxDials¹
979              The  default  value  for  the maximum number of times the server
980              will place a call for an outbound job.  This value may be  over‐
981              ridden  by  rules  in the JobControl mechanism.  This feature is
982              completely distinct from the identically-named  feature  in  the
983              client-server  communication,  and  jobs triggering these limits
984              will be handled differently for each.  See also MaxTries.
985
986       MaxProxyJobs¹
987              The maximum number of jobs which can be  concurrently  delivered
988              to a proxy for transmission.  This limit is to prevent proxy use
989              from overwhelming available system processes.
990
991       MaxRecvPages
992              The maximum number of pages the server will accept in a received
993              facsimile before it aborts the session.
994
995       MaxSendPages¹
996              The  default  value  for  the maximum number of pages the server
997              will permit in a transmitted facsimile.  Outbound jobs that  ex‐
998              ceed  this  limit are rejected.  This value may be overridden by
999              rules in the JobControl mechanism.
1000
1001       MaxSetupAttempts
1002              The maximum number of times a HylaFAX server  program  will  at‐
1003              tempt to initialize a modem before considering it ``wedged''.
1004
1005       MaxTraversal¹
1006              The  maximum  depth  into the job queues that the scheduler will
1007              traverse in attempts to batch jobs together in  a  single  call.
1008              This  is intended to prevent the scheduler from wasting a lot of
1009              CPU in batching attempts when  the  job  queues  get  very  long
1010              (where batching is unlikely to be useful anyway).
1011
1012       MaxTries¹
1013              The  default  value  for  the maximum number of times the server
1014              will attempt to communicate with a remote site.  Note that for a
1015              call  to  be  counted against this limit, carrier must be estab‐
1016              lished; this is in contrast to the value of MaxDials which  lim‐
1017              its  the number of calls that will be placed on behalf of a job.
1018              This value may be overridden by rules in the  JobControl  mecha‐
1019              nism.  This feature is completely distinct from the identically-
1020              named feature in the client-server communication, and jobs trig‐
1021              gering  these  limits will be handled differently for each.  See
1022              also MaxDials.
1023
1024       MinAcceptedLineCount
1025              The minimum number of received scanlines allowed  on  an  ``OK''
1026              page.   The use of this setting prevents confirmation from being
1027              sent for very short pages.
1028
1029       MissedPageHandlingMethod
1030              (Class 1/1.0 only) Specifies how to react to a missed  page  re‐
1031              ceived from the remote sender: one of ``RTN'', ``PIN'', ``DCN'',
1032              or ``CFR''.
1033
1034              If a page is missed (where the modem does not train on the Phase
1035              C  carrier) in non-ECM mode then, like BadPageHandlingMethod, it
1036              can be somewhat difficult to inform the sender of the problem.
1037
1038              A setting of ``RTN'' is the proper behavior  that  fax  protocol
1039              employs to request that the sender retransmit the page after re‐
1040              training.  Unfortunately, however, some  senders  will  perceive
1041              this  as  a receipt confirmation and not retransmit the page. If
1042              senderConfusesRTN is set to ``yes'' in the  associated  hylafax-
1043              info(5F)  file  for  this  sender,  then this method will not be
1044              used.
1045
1046              A setting of ``PIN'' is the proper behavior  that  fax  protocol
1047              employs  to  request that the sender retransmit the page after a
1048              procedural interrupt.  However, procedural interrupts are rarely
1049              used  and  may  not  be  widely  supported  by other systems. If
1050              senderConfusesPIN is set to ``yes'' in the  associated  hylafax-
1051              info(5F)  file  for  this  sender,  then this method will not be
1052              used.
1053
1054              A setting of ``DCN'' should  trigger  a  call  abortion  by  the
1055              sender.   This  should clearly indicate a problem to the sender,
1056              although a retransmission attempt in  a  later  call  cannot  be
1057              guaranteed.
1058
1059              A  setting  of  ``CFR'' causes an out-of-spec behavior where the
1060              CFR signal is used in response to the post-page message.   While
1061              other HylaFAX senders should handle this signal to lead to a re‐
1062              transmision of the page without retraining,  most  senders  will
1063              disconnect  after receiving this signal as it is not a permitted
1064              response in Phase D, and the sender response will be  undefined.
1065              This method will only be used if it is explicitly configured for
1066              use.
1067
1068              Historically, HylaFAX has employed both ``RTN'' and ``DCN''  be‐
1069              haviors  by  default  with complaints using either.  The ``PIN''
1070              and ``CFR'' behaviors were developed in  order  to  evaluate  if
1071              other systems besides HylaFAX would tolerate them.
1072
1073              MissedPageHandlingMethod  is designed to allow the administrator
1074              the opportunity to vary between these options through the Dynam‐
1075              icConfig feature to acheive a more nuanced approach.
1076
1077       ModemGroup¹
1078              Define  a logical name for a set of modem devices.  This parame‐
1079              ter can be used to define a name that clients can use  to  refer
1080              to  a  collection  of  modems.   The syntax is ``<name>:<defini‐
1081              tion>'' where <name> is the name for the group and  <definition>
1082              is  of  the syntax ``[<limit>:]<regex>'' where <limit> is an op‐
1083              tional formatted expression of the limits  for  this  ModemGroup
1084              and  <regex>  is  a  regular  expression  that  faxq(8C) matches
1085              against known modems.  Presently <limit> only refers to a number
1086              that  is  the minimum number of modems in the group that must be
1087              left to stay idle (for receiving) after assigning an active  job
1088              to  the ModemGroup.  The default for <limit> is 0.  Thus for ex‐
1089              ample, the default modem to use for a job, any,  is  defined  as
1090              ``any:0:.*''.  This parameter may be specified multiple times to
1091              define multiple modem classes.  Modem classes may overlap.   The
1092              actual  set  of  modems in a modem class that are considered for
1093              use may vary based on which modems are believed to be ready  for
1094              use.
1095
1096       ModemPriority
1097              The scheduling priority to use for a modem.  Priority values are
1098              in the range 0 to 255 with lesser values signifying higher (more
1099              desirable)  priority.  The HylaFAX scheduler process assigns the
1100              highest priority modem that is ready for use when scheduling  an
1101              outbound job.
1102
1103              If multiple available modems in a job's selected ModemGroup have
1104              the same ModemPriority value, then the HylaFAX scheduler assigns
1105              jobs to them in a round-robin fashion.
1106
1107       NoAnswerVoice
1108              Whether  or  not  to disable the answering of calls indicated as
1109              voice (e.g. by DistinctiveRings ).
1110
1111       NoCarrierRetrys
1112              This is mapped onto JobRetryNoCarrier
1113
1114       ModemReadyState
1115              Define the state transmitted to the  HylaFAX  scheduler  process
1116              each time a modem is made ready by a faxgetty process.  State is
1117              one of: ``R'' (ready for use), ``B'' (busy),  ``D''  (down),  or
1118              ``E''  (exempt).  The modem state can be used to control whether
1119              or not modems are assigned to outbound jobs.  A modem's state is
1120              initially  set to ``R'' (ready).  Modem state can be dynamically
1121              changed with the faxstate(8C) program or by setting this config‐
1122              uration  parameter  with the faxconfig(8C) program.  The HylaFAX
1123              scheduler process will not assign jobs to a modem with a  Modem‐
1124              ReadyState  of  anything  other than ``R''.  The differences be‐
1125              tween ``B'', ``D'', and ``E'' are that ``B'' refers to a  tempo‐
1126              rary  condition  that will automatically clear in the passing of
1127              time (as if the modem were in-use with receiving a  fax);  ``D''
1128              refers to a condition that will not automatically clear (such as
1129              a wedged condition); and ``E'' refers to a  permanent  condition
1130              as  configured  by  the administrator (as for a receive-only mo‐
1131              dem).  If a user submits a job to a specific modem  that  has  a
1132              ModemReadyState  of ``B'' or ``D'' then the job will wait in the
1133              queue until the modem is made available or until the  job  times
1134              out.   In  contrast,  jobs  submitted to a specific modem with a
1135              ModemReadyState of ``E''  will  be  rejected  outright.   Exempt
1136              modems  should  be removed from any ModemGroup to which they be‐
1137              long (i.e. ``any'').
1138
1139       ModemRingResponse
1140              This can be used to cause the command  defined  by  ModemRingRe‐
1141              sponse  to  be  sent  to the modem after hearing at least Modem‐
1142              RingsBeforeResponse RINGs in order to receive DID-DTMF data, for
1143              example.
1144
1145       ModemRingsBeforeResponse
1146              This  defines the minimum number of RINGs that must be heard be‐
1147              fore ModemRingResponse is first sent to the modem.
1148
1149       NotifyCmd²
1150              The program to invoke to notify a client of a job status change;
1151              see notify(8C).
1152
1153       PageChop¹
1154              Whether  or not to automatically truncate trailing whitespace on
1155              pages of outbound facsimile (when possible).  If  page  chopping
1156              is  enabled, then pages with at least PageChopThreshold trailing
1157              whitespace on a page will be transmitted as a ``short page''  if
1158              the receiver is capable of accepting variable-length pages.  The
1159              possible values are: ``last'' to enable  chopping  of  the  last
1160              page  of each document, ``all'' to enable chopping of all pages,
1161              or ``none'' to disable page chopping.
1162
1163       PageChopThreshold¹
1164              The minimum amount of trailing whitespace that must  be  present
1165              on  a page before page chopping will be attempted; see PageChop.
1166              Note that this value is specified in inches.
1167
1168       PCL2FaxCmd¹
1169              The command to invoke to convert a HP-PCL document submitted for
1170              transmission to TIFF/F, suitable for transmission.
1171
1172       PercentGoodLines
1173              The minimum percentage of good rows of image data required for a
1174              received facsimile page to be deemed  to  have  acceptable  copy
1175              quality.   Setting  this  parameter to zero causes the server to
1176              not check the quality of received facsimile.  Facsimile received
1177              with  error-correction  do  not  have copy quality checking per‐
1178              formed.  See also MaxConsecutiveBadLines.
1179
1180       PollLockPokeModem
1181              When polling for the presence/removal of a UUCP  lockfile,  also
1182              test  to make sure the modem is still reachable.  This is useful
1183              for scenarios where the modem  is  apt  to  become  disconnected
1184              while the modem is idle, such as an external modem that may lose
1185              power, where the administrator wants notification of this (as  a
1186              ``wedged'' condition).
1187
1188       PollLockWait
1189              When  polling  for  the presence/removal of a UUCP lockfile, the
1190              time (in seconds) to wait between checks.  Lockfile polling  oc‐
1191              curs  to  ensure  the  fax  server  doesn't collide with another
1192              process using the modem.
1193
1194       PollModemWait
1195              The time (in seconds) to wait between checks for a modem to  be‐
1196              come  ready for use.  Modem polling occurs when a modem fails to
1197              reset cleanly.
1198
1199       PriorityScheduling
1200              Indicates whether the HylaFAX scheduler should utilize available
1201              priority  job  scheduling  mechanisms to enhance realtime execu‐
1202              tion, particularly with  Class  1  configurations  on  older  or
1203              slower systems.
1204
1205              Currently  PriorityScheduling  is available for IRIX, SVR/4, HP-
1206              UX, and POSIX-compliant (i.e. Linux) operating systems.  The de‐
1207              fault value varies to maintain traditional HylaFAX behavior.  On
1208              IRIX, SVR/4, and HP-UX systems where the  configure  script  de‐
1209              tects  one  of  the functions schedctl(), priocntl() or rtprio()
1210              the default is true.  The only other supported  priority  mecha‐
1211              nism  is  POSIX  sched_setscheduler(),  which  is used on Linux,
1212              OpenServer and possibly other systems.  On such systems, as well
1213              as on systems where no priority scheduling mechanism exists, the
1214              default is false."
1215
1216       PS2FaxCmd¹
1217              The command to invoke to convert a POSTSCRIPT document submitted
1218              for  transmission  to  TIFF/F,  suitable  for  transmission; see
1219              ps2fax(8C).
1220
1221       QualifyPWD
1222              A string that specifies whether or not the identity  of  calling
1223              facsimile  machines  should be checked against an access control
1224              list before receiving facsimile.   If  QualifyPWD  is  non-null,
1225              then  only  messages  from  facsimile machines identified in the
1226              file specified by the string (typically etc/passwd) will be  ac‐
1227              cepted; similar to QualifyTSI.
1228
1229       QualifyTSI
1230              A  string  that specifies whether or not the identity of calling
1231              facsimile machines should be checked against an  access  control
1232              list  before  receiving  facsimile.   If QualifyTSI is non-null,
1233              then only messages from facsimile  machines  identified  in  the
1234              file  specified  by  the  string (typically etc/tsi) will be ac‐
1235              cepted; see tsi(5F).  If QualifyTSI is not specified in the con‐
1236              figuration file, or the value is null, then all incoming facsim‐
1237              ile messages will be accepted.
1238
1239       RecvDataFormat
1240              The data format (compression scheme) to write received facsimile
1241              data when copy quality checking is performed on the host.  (When
1242              copy quality checking is not done by  the  server,  for  example
1243              when  error  correction protocol is used, the received facsimile
1244              data is written exactly as it is received from the modem.)   The
1245              format  may  be  one:  ``1-D  MH'',  ``2-D MR'', ``2-D MMR'', or
1246              ``adaptive''.  An ``adaptive'' format causes the  received  data
1247              to be written using the data format negotiated by the sender and
1248              receiver.  Note that while 2-D MMR is the  most  space-efficient
1249              data format the resultant file may not be viewable (certain com‐
1250              monly used programs do not properly read multi-strip  TIFF  with
1251              2-D MMR data).
1252
1253       RecvFileMode
1254              The file protection mode that should be used when creating files
1255              to hold incoming facsimile.  Note that this value  is  given  in
1256              octal.   The default value of 0600 implies that only the facsim‐
1257              ile user can read received facsimile.  If incoming facsimile are
1258              to  be  publicly accessible, this value may be set, for example,
1259              to 0644.  See also chmod(2).
1260
1261       RejectCall
1262              If this is set to true, the current call will not  be  answered,
1263              and  will  be rejected.  This option has no effect if set in the
1264              configuration file, but when set by the  DynamicConfig  program,
1265              controls the current call.  This options supersedes the obsolete
1266              QualifyCID option.
1267
1268       RingData
1269              A modem status string that identifies that an incoming  call  is
1270              for  data  use.  This string should be set when a phone line has
1271              been setup with distinctive ring service.  See also RingFax  and
1272              RingVoice.
1273
1274       RingExtended
1275              An  identifier  which matches the initial portion of an extended
1276              RING message sent by the modem to relay CID and/or DNIS data in‐
1277              stead of sending it formatted on separate lines.
1278
1279       RingFax
1280              A  modem  status string that identifies that an incoming call is
1281              for facsimile use.  This string should be set when a phone  line
1282              has been setup with distinctive ring service.  See also RingData
1283              and RingVoice.
1284
1285       RingsBeforeAnswer
1286              The number of rings to wait before answering the phone.  If this
1287              value  is  set to 0, then the phone will only be answered in re‐
1288              sponse to an explicit answer command; see faxanswer(8C).
1289
1290       RingTimeout
1291              If a ring is heard and the call is not answered, the time in  ms
1292              to wait before reinitializing the modem for the next call.
1293
1294       RingVoice
1295              A  modem  status string that identifies that an incoming call is
1296              for voice use.  This string should be set when a phone line  has
1297              been setup with distinctive ring service.  See also RingData and
1298              RingFax.
1299
1300       RTNHandlingMethod
1301              Specifies how to react to an RTN signal received  from  the  re‐
1302              mote:  one  of  ``Retransmit'',  ``Giveup'',``Ignore'', or ``Re‐
1303              transmit-Ignore''.
1304
1305              ``Retransmit'' assumes that the page is  not  received  success‐
1306              fully.   HylaFAX will make up to two additional attempts to send
1307              the page, decreasing signalling rate  and  retraining.   If  RTN
1308              continues,  up  to 2 additional calls will be placed.  The down‐
1309              side is that if the remote always responds with  RTN,  the  page
1310              will  be sent 9 times and no following pages will be sent.  Many
1311              fax machines will not behave this way, although T.30  specifica‐
1312              tion seems clear that this is the intent of the RTN signal.
1313
1314              Some  fax machines will interpret RTN as meaning to not send the
1315              same data again.  That is because RTN may indicate problems with
1316              flow  control,  incorrectly encoded T.4 data, or some incompati‐
1317              bility other than line noise.  Fax machines that  interpret  RTN
1318              this  way  will  disconnect and require a manual retransmission.
1319              This  ``over  and  out''  behavior  can  be  activated  by   the
1320              ``Giveup''  value.   The  advantage to this behavior is that the
1321              same page of image data will not be sent multiple times, but the
1322              downside is that the following pages will not be sent.
1323
1324              ``Ignore'' is similar to ``Giveup'' in that it makes the assump‐
1325              tion the data cannot be automatically accepted by the  receiver.
1326              However,  rather  than  disconnecting  the page of image data is
1327              abandoned and processing moves on to the next.   The  remote  is
1328              left  to  decide  what to do with the unacceptable page of image
1329              data.  The downside to this behavior, is that the remote may  or
1330              may  not  have kept the page, depending on its interpretation of
1331              the RTN signal - but it does allow us to continue on to the next
1332              page.
1333
1334              ``Retransmit-Ignore''  is  a  combination  of ``Retransmit'' and
1335              ``Ignore''.  The page of image data is retransmitted up  to  two
1336              additional  times,  but  rather than disconnecting after a third
1337              RTN signal for the same page, processing then  continues  on  to
1338              the  next  page.  This approach is an effort to satisfy both in‐
1339              terpretations of an RTN signal.  It allows the receiver to hope‐
1340              fully  receive a better copy of the image data while not failing
1341              to send subsequent pages.  If the receiver  saves  or  prints  a
1342              copy  of pages for which it transmits RTN, then it could save or
1343              print up to three copies of every page.
1344
1345       SaveUnconfirmedPages
1346              Whether or not to save a received facsimile image  page  if  the
1347              sender  disconnects without sending the post-page message, with‐
1348              out hearing our message confirmation, without retraining as  re‐
1349              quested,  or  otherwise breaks fax protocol following such pages
1350              for which the sender should not have a ``receipt confirmation''.
1351
1352       SendFaxCmd¹
1353              The command to use  to  process  outbound  facsimile  jobs;  see
1354              faxsend(8C).
1355
1356       SendPageCmd¹
1357              The  command  to  use  to process outbound pager jobs; see page‐
1358              send(8C).
1359
1360       SendUUCPCmd¹
1361              The command to use to process outbound UUCP jobs.  This  parame‐
1362              ter is not currently used, it is for future development.
1363
1364       ServerTracing²
1365              A  number that controls the generation of tracing information by
1366              a server when  not  actively  sending  or  receiving  facsimile.
1367              Tracing  is divided into areas that are individually controlled.
1368              To enable tracing of multiple areas of operation, the flag asso‐
1369              ciated  with  each area should be bit-or'd to form the value for
1370              this tag.
1371              Flag                Area                    Description
1372              1 (0x00001)         Server Operation        queue management and general operation
1373              2 (0x00002)         FAX/IXO Protocol        T.30 facsimile protocol or IXO/TAP protocol
1374              4 (0x00004)         Modem Operations        modem hardware manipulation
1375              8 (0x00008)         Modem Communications    commands passed between host and modem
1376              16 (0x00010)        Timeouts                timer operations
1377              32 (0x00020)        Modem Capabilities      modem capabilities
1378              64 (0x00040)        HDLC Frames             binary T.30 HDLC frames
1379              128 (0x00080)       Binary Modem I/O        binary communication between host and modem
1380              256 (0x00100)       Server State Transitionsserver program state transitions
1381              512 (0x00200)       Queue Management        job queue management
1382              1024 (0x00400)      Copy Quality            copy quality checking of received facsimile
1383              2048 (0x00800)      Job Management          low-level job management
1384              4096 (0x01000)      IXO Protocol            low-level IXO protocol
1385              8192 (0x02000)      Config File Parsing     unknown configuration file parameters
1386              16384 (0x04000)     FIFO Messages           inter-application messages
1387              32768 (0x08000)     Modem State Transitions modem state changes (down, busy, ready)
1388              65536 (0x10000)     Dial Rules              dialstring rules parsing and execution
1389              131072 (0x20000)    Docq Changes            document reference handling
1390              262144 (0x40000)    TIFF library            any messages produced by the TIFF library
1391              524288 (0x80000)    ECM Frames              binary T.30-A HDLC ECM frames
1392              For example, to enable tracing of server operations and protocol
1393              operations,  a  value of 1+2=3 should be specified.  NB: tracing
1394              timeouts and/or binary modem I/O can adversely affect the opera‐
1395              tion of the fax server; enabling these areas should be done with
1396              extreme care.
1397
1398              Server tracing is directed to syslog(3) using the facility spec‐
1399              ified  with  the LogFacility configuration parameter.  Note that
1400              syslogd(8C) must be configured to capture facility.info,  facil‐
1401              ity.debug, facility.warning, and facility.err messages.  See hy‐
1402              lafax-log(5F) for a description of the logged messages.
1403
1404       SessionTracing²
1405              A number that controls the generation of tracing information  by
1406              a  server  while  sending or receiving facsimile.  The number is
1407              interpreted identically to  ServerTracing.   Note  that  session
1408              tracing  is placed in log files in the log subdirectory; see hy‐
1409              lafax-log(5F) for more information.
1410
1411       ShareCallFailures²
1412              A string which indicates the types of call failures that  should
1413              be  shared  to blocked jobs (in the scheduler config file) or to
1414              batched jobs (in the per-device configuration files).  The  pur‐
1415              pose  of this configuration is to prevent a large set of jobs to
1416              the same destination from stalling for long periods of  time  in
1417              the queue and repeatedly initiating failed delivery attempts due
1418              to call-related errors (such as an incorrectly-entered  destina‐
1419              tion  number).   Jobs which are batched or blocked (depending on
1420              which configuration file is used) will receive the same  failure
1421              indication  and  ``dials'' increment as the job which was active
1422              and running at the time (or lead the batch).   ShareCallFailures
1423              may  contain  the  following  key  words  in  any order with any
1424              deliniation:
1425
1426              Key Word    Meaning
1427              busy        Busy signal detected
1428              nocarrier   No carrier detected
1429              noanswer    No answer from remote
1430              nodialtone  No local dialtone
1431
1432              Alternatively, ShareCallFailures may be  set  exactly  to  ``al‐
1433              ways''  which  makes  it  apply to all of the call failure types
1434              listed above and is synonymous with  ``busy  nocarrier  noanswer
1435              nodialtone''.
1436
1437       SpeakerVolume
1438              The volume level that the in-modem speaker should be adjusted to
1439              while in command mode.  The possible values are:
1440              Value     Description
1441              Off       silent
1442              Quiet     almost inaudible
1443              Low       tolerable in privacy
1444              Medium    loud enough to hear in the next room
1445              High      intolerable
1446              Note that the speaker is always turned off once carrier  is  es‐
1447              tablished.   Also  beware  that some modems support fewer volume
1448              settings; see ModemSetVolumeCmd.
1449
1450       StaggerCalls¹
1451              The time, in seconds, to delay between initiating  outbound  job
1452              calls.   If HylaFAX is using a single phone line shared for both
1453              sending and receiving of faxes using a StaggerCalls setting  of,
1454              for  example,  300  would  ensure that outbound calls be made in
1455              succession no more frequently than every 5 minutes, thus  allow‐
1456              ing time between jobs for incoming calls to be received.
1457
1458       TagLineFont
1459              The  filename of the font to use in imaging tag lines across the
1460              top of each transmitted page.  Fonts must be stored in the  Por‐
1461              table  Compiled Font (PCF) format used by the X11 Window System.
1462              Filenames are specified relative to the  root  of  the  spooling
1463              area;  e.g. etc/lutRS18.pcf or etc/LiberationSans-25.pcf.  If no
1464              font is specified, if a null filename is specified,  or  if  the
1465              specified  font file is not readable, then tag lines will not be
1466              generated.  Note that the etc/lutRS18.pcf TagLineFont  that  has
1467              historically  been the default with HylaFAX does not have glyphs
1468              available beyond basic ASCII, and to show non-ASCII characters a
1469              different  file  must be used that has characters matching those
1470              characters found in TagLineFormat as decoded by  the  TagLineLo‐
1471              cale setting.  For this reason, the etc/LiberationSans-25.pcf is
1472              now considered the default as it has unicode support for  Latin,
1473              Greek, and Cyrillic characters.
1474
1475       TagLineFormat
1476              The  format  string to use when imaging tag lines across the top
1477              of each transmitted page.  This string may include escape  codes
1478              that  cause various items to be interpolated into the imaged tag
1479              line.  Any escape code supported by strftime(3C)  (which  use  a
1480              single ``%'') may be used as well as the following server-imple‐
1481              mented codes:
1482              Escape    Description
1483              %%a       destination subaddress
1484              %%c       destination company name
1485              %%C       sender's company name
1486              %%d       destination phone number
1487              %%g       sender's geographic location
1488              %%G       destination geographic location
1489              %%i       job identifier
1490              %%I       group identifier
1491              %%j       user-specified job tag
1492              %%l       job TSI or LocalIdentifier or canonicalized FAXNumber
1493              %%m       sender's electronic mail address
1494              %%n       canonicalized FAXNumber
1495              %%p       current page number of session
1496              %%P       current page number of job
1497              %%r       receiver's name
1498              %%s       sender's name
1499              %%S       subject
1500              %%t       total pages in session
1501              %%T       total pages in job
1502              %%v       sender's voice number
1503              %%V       destination voice number
1504              %%%       ``%''
1505              There are  numerous  date  and  time  format  options  available
1506              through strftime(3C).  Users are encouraged to refer to its doc‐
1507              umentation for elaboration.  Used by default, ``%c'' is  defined
1508              as  ``The preferred date and time representation for the current
1509              locale.''
1510
1511              In addition, the format string may indicate that text is  to  be
1512              broken  into multiple equal-sized fields by separating text with
1513              ``|'' characters.  If the first character  in  the  field  is  a
1514              ``{''  then  the text is left-aligned; if the first character in
1515              the field is a ``}'' then the text is right-aligned;  otherwise,
1516              the  text  is  centered  in the field.  For example, ``{a|b|}c''
1517              would cause the tag line to be broken up into three  equal-sized
1518              areas  with  the  string ``a'' left-aligned in the first region,
1519              ``b'' centered in the second region, and ``c'' right-aligned  in
1520              the  third region.  The default tag line format string is ``From
1521              %%n|%c|Page %%P of %%T''.  The differences between  the  %%p  or
1522              %%P and the %%t or %%T options are noticed when a fax job is re‐
1523              tried after an incomplete attempt and only the previously unsent
1524              pages  are  then  queued  in  a  successive  session.   See also
1525              TagLineFont.
1526
1527       TagLineLocale
1528              The locale setting  for  handling  TagLineFormat,  for  example,
1529              ``en_US.UTF-8''.  If TagLineFormat is encoded via UTF-8 then the
1530              correct setting of TagLineLocale is requisite for proper  decod‐
1531              ing  by  the  parser.   By  default the environment settings are
1532              used.
1533
1534       TIFF2FaxCmd²
1535              The command to invoke to convert a TIFF submitted for  transmis‐
1536              sion to TIFF/F, suitable for transmission; see tiff2fax(8C).  In
1537              the scheduler configuration file this is used  in  outbound  job
1538              preparation.  In the per-device configuration files this is used
1539              in conjunction with RTFCC features for comparing  relative  data
1540              sizes between different formats.
1541
1542       TimeOfDay¹
1543              The  default time-of-day restrictions to apply to outbound jobs.
1544              Outbound jobs will be processed only during the specified  time.
1545              Any  jobs  submitted outside this time period will be held until
1546              the start of this time.  The syntax for time-of-day restrictions
1547              is  designed  to  be compatible with the syntax used by the UUCP
1548              software.  The following BNF describes the syntax:
1549                 Syntax = tod ["," tod]
1550                    tod = <days><timerange>
1551                   days = "Any" | "Wk" | <dayname>+ | nothing
1552                dayname = "Sun" | "Mon" | "Tue" | "Wed" | "Thu" | "Fri" | "Sat"
1553              timerange = <start> "-" <end> | nothing
1554                  start = <24hrtime>
1555                    end = <24hrtime>
1556               24hrtime = {0-9}{0-9}{0-9}{0-9}
1557                nothing =
1558              where start and end are 24-hour times, day names can  be  either
1559              2-  or  3-characters, and a null day or time specification means
1560              any time or day.  White space and other syntactic sugar  may  be
1561              freely  inserted  between tokens but may not be inserted between
1562              24-hour times in the time range.
1563
1564              This value may be overridden by rules in the  JobControl  mecha‐
1565              nism.
1566
1567       TSIRecvdCmd
1568              The  pathname  of  the  optional program, e.g. ``etc/tsirecvd'',
1569              that similar to DynamicConfig can set the RejectCall  option  to
1570              cause  the  current  call  to  be rejected instead of continued.
1571              TSIRecvdCmd should provide a more capable mechanism than  Quali‐
1572              fyTSI  for  those wishing to screen calls based on received TSI.
1573              Note that this file must be marked as executable by the faxgetty
1574              process.  Note also that any configuration modifications made by
1575              the TSIRecvdCmd script other than RejectCall is unsupported  and
1576              has undefined results.
1577
1578       Unblock¹
1579              Intended  to  only  be used from the faxconfig(8C) utility, this
1580              will force faxq(8C) to unblock one call to  the  value-specified
1581              destination  number.   The destination number should be provided
1582              in the format known by faxq(8C), as seen in the hylafax-info(5F)
1583              database files.
1584
1585       Use2D¹ Control the use of 2D-encoded data for transmitted facsimile.
1586
1587       UseJobTagLine
1588              Allow  the  use of the job-specified tagline instead of the con‐
1589              figured TaglineFormat
1590
1591       UUCPLockMode²
1592              The file protection mode that should be used when creating  UUCP
1593              lockfiles.  Note that this value is given in octal.
1594
1595       UUCPLockDir²
1596              The  pathname of the directory in which UUCP lockfiles are to be
1597              created.
1598
1599       UUCPLockTimeout²
1600              The time in seconds to wait before removing a stale  UUCP  lock‐
1601              file (i.e. a lockfile whose owner does not appear to exist).  If
1602              this value is set to 0, then the fax server will never remove  a
1603              stale lockfile.
1604
1605       UUCPLockType²
1606              A  string  that  specifies  the type of UUCP lockfile to create.
1607              The string may be one of ``ascii'' or  ``binary''  depending  on
1608              whether  the process-ID of the lock owner is written to the file
1609              as an ascii string or as a binary value, respectively.  In addi‐
1610              tion, two prefixes may be used to control the format of the lock
1611              filename.  If the type string is prefixed  with  a  ``+'',  then
1612              SVR4-style filenames are generated using the major device number
1613              of the tty device and the major and minor device numbers for the
1614              filesystem  on which the tty device resides.  If the type string
1615              is prefixed with a ``-'', then any upper case letters in the de‐
1616              vice  part of the lockfile name are converted to lower case let‐
1617              ters;   for   example,   ``LCK..ttyA01''   is    converted    to
1618              ``LCK..ttya01''.   This upper-to-lower case conversion is useful
1619              for systems such as SCO where the convention is to name  devices
1620              with  upper-case  letters,  but create lockfiles with lower-case
1621              letters.
1622
1623       VGettyArgs
1624              A string that indicates whether or not the server should  invoke
1625              a voice getty program in response to an incoming voice call.  If
1626              the string value is not null, then it is interpreted as a set of
1627              arguments  to  pass to the vgetty program.  Before supplying the
1628              arguments, the string is  first  scanned  for  ``%''-escape  se‐
1629              quences:  any appearance of ``%l'' is replaced with the tty name
1630              and any appearance of ``%s'' is replaced with  the  serial  port
1631              speed (in decimal).  Any appearance of escaped numbers 1 through
1632              9 (``%1'' through ``%9'') are replaced by the match to the  cor‐
1633              responding  CallIDPattern,  if present.  The ``%'' character can
1634              be specified with ``%%''.  If the VGettyArgs  parameter  is  not
1635              specified  in  the  configuration file or if the string value is
1636              null, then voice connections will be rejected.  Note that in ad‐
1637              dition  to the specified command line arguments, the vgetty pro‐
1638              gram is invoked with its standard input, output, and  error  de‐
1639              scriptors directed to the controlling tty device.
1640
1641       WedgedCmd¹
1642              The  program  to  invoke  when a modem is deemed ``wedged''; see
1643              wedged(8C).
1644

MODEM-ORIENTED CONFIGURATION PARAMETERS

1646       This section lists configuration parameters that are  specific  to  the
1647       setup  and  operation of the modem.  All commands must be specified ex‐
1648       actly as they are to be transmitted to the modem (note that this  is  a
1649       departure  from  previous  versions of this software that automatically
1650       prepended ``AT'' to each line of commands sent  to  the  modem).   When
1651       multi-line  commands  are required, enclose the commands in quote marks
1652       (``"'') and insert a newline character ``\n''  where  lines  should  be
1653       broken.     An    example   of   a   multi-line   command   string   is
1654       ``AT+FCQ=1\nAT+FBADMUL=20\nAT+FBADLIN=10''.
1655
1656       Command strings sent to the modem  may  include  command  escapes  that
1657       force  the  host to alter the DTE-DCE communication rate, the flow con‐
1658       trol scheme used between the host and modem,  delay  for  a  period  of
1659       time,  flush  input data, and wait for a specific response from the mo‐
1660       dem.  The following escape codes are interpreted:
1661              Escape      Effect
1662              <none>      enable no flow control between DTE and DCE
1663              <xon>       enable software flow control between DTE and DCE
1664              <rts>       enable hardware flow control between DTE and DCE
1665              <2400>      set the DCE-DTE baud rate to 2400 bps
1666              <4800>      set the DCE-DTE baud rate to 4800 bps
1667              <9600>      set the DCE-DTE baud rate to 9600 bps
1668              <19200>     set the DCE-DTE baud rate to 19200 bps
1669              <38400>     set the DCE-DTE baud rate to 38400 bps
1670              <57600>     set the DCE-DTE baud rate to 57600 bps
1671              <76800>     set the DCE-DTE baud rate to 76800 bps
1672              <115200>    set the DCE-DTE baud rate to 115200 bps
1673              <delay:N>   delay N x 10 ms on the host (0 <= N <= 255)
1674              <flush>     flush any pending input data from the modem
1675              <waitfor:R> wait for the response R from the modem (see below)
1676              <play:C>    play the etc/playC.raw audio file (see below)
1677       Note that commands to the left of an escape code are sent to the  modem
1678       before the associated actions are carried out on the host.  This may be
1679       important when changing baud rates, as the result code from  a  command
1680       may  be  returned at the new baud rate.  Also, beware that not all baud
1681       rates are supported by all systems and modems; the set  of  baud  rates
1682       supported by a host is usually listed in stty(1).
1683
1684       The  ``<waitfor:..>'' escape can be used to override the default behav‐
1685       ior which is to wait for an ``OK'' response to a command  sent  to  the
1686       modem.  The possible response codes are:
1687              NOTHING       a null response
1688              OK            the default response
1689              CONNECT       ``CONNECT...''
1690              NOANSWER      ``NO ANSWER...''
1691              NOCARRIER     ``NO CARRIER...''
1692              NODIALTONE    ``NO DIALTONE...''
1693              BUSY          ``BUSY''
1694              OFFHOOK       ``PHONE OFF-HOOK''
1695              RING          ``RING...''
1696              ERROR         error status from modem
1697              VCON          voice connection indicator
1698              OTHER         any unrecognized modem response
1699       For  example ``ATO\r<waitfor:CONNECT>'' would send ``ATO\r'' to the mo‐
1700       dem and then wait for a response with a leading ``CONNECT'' in it;  and
1701       ``ATS99=2\r<delay:2><flush><waitfor:NOTHING>'' would send ``ATS99=2\r''
1702       to the modem, delay 20 ms, flush any input from  the  modem,  and  then
1703       continue (not wait for any response).
1704
1705       The  ``<play:C>''  escape  can  be used to play a raw audio file with a
1706       voice modem.  The files are named  etc/playC.raw  where  ``C''  is  any
1707       character.   This feature can be used, for example, to play a brief au‐
1708       dio message after picking up the line but before answering.  A configu‐
1709       ration example may be:
1710
1711         ModemRingResponse:  "AT+FCLASS=8;H1\nAT+VSM=131\nAT+VLS=1\nAT+VTX\n<waitfor:CONNECT><play:1><waitfor:OK>AT+VTS=[933,,150]"
1712         ModemAnswerCmd:     "<delay:100>AT+FCLASS=1;A"
1713         CallIDPattern:      SHIELDED_DTMF
1714         CallIDAnswerLength: 4
1715
1716       In  this  example using an IS-101 voice-compliant modem, a RING indica‐
1717       tion from the modem will cause the modem to be placed  in  voice  mode,
1718       set  ulaw audio compression, and via the connected phone line play back
1719       the etc/play1.raw audio file, which may say, "After the  tone  enter  a
1720       four-digit  extension,  then  start  the fax."  Following the message a
1721       tone is played.
1722
1723       ModemAnswerCmd
1724              The command to answer the  phone.   If  possible,  this  command
1725              should  generate a result string that identifies whether the in‐
1726              coming call is from a facsimile, voice, or  data  modem.   Typi‐
1727              cally this auto-detection is configured ahead of time; e.g.  for
1728              Class 2 modems with the ``AT+FAA=1'' command.
1729
1730              The following table describes how the result  codes  are  inter‐
1731              preted by the facsimile server.
1732              Result String    Default          Class 1      Class 2      Class2.0
1733              CONNECT FAX      Fax              -            -            --
1734              CONNECT          Data             Unknown      -            -
1735              NO ANSWER        No Answer        -            -            -
1736              NO CARRIER       No Carrier       -            -            -
1737              NO DIALTONE      No Dialtone      -            -            -
1738              ERROR            Error            -            -            -
1739              FAX              Fax              -            -            -
1740              DATA             Data             -            -            -
1741              +FCON            -                -            Fax          Fax
1742              +FCO             -                -            Fax          Fax
1743              +FDM             -                -            Data         Data
1744              +FHNG:           -                -            Error        Error
1745              VCON             -                -            Voice        Voice
1746              The ``Default'' column indicates the interpretation made for the
1747              result string in either class 1 or 2 unless explicitly  overrid‐
1748              den.   The  ``Class  1'' column indicates result strings handled
1749              specially for modems operating in class 1, the ``Class 2''  col‐
1750              umn  indicates special handling for modems operating in class 2,
1751              and the ``Class 2.0''  column  indicates  special  handling  for
1752              modems  operating  in class 2.0.  Unknown entries imply that in‐
1753              terpretation is based on the way in which the call was answered;
1754              if answering is done for an explicit call type, that type is as‐
1755              sumed, otherwise a Fax call is presumed.
1756
1757       ModemAnswerAgainCmd
1758              The command to answer the phone  if  ModemAnswerCmd  appears  to
1759              have been ignored.  Typically this should include a delay escape
1760              in order to set the timing of the answer away from the  ring  in
1761              case  the  modem  is incapable of answering so closely following
1762              the ring.
1763
1764       ModemAnswerDataBeginCmd
1765              The command to send to the modem once a data connection has been
1766              established.
1767
1768       ModemAnswerDataCmd
1769              The  command  to  explicitly answer the phone for a data connec‐
1770              tion.  This command must generate a result string  that  identi‐
1771              fies  the incoming call is from a data modem.  If this parameter
1772              is not specified or is null, then the value of ModemAnswerCmd is
1773              used instead.  See also AdaptiveAnswer and AnswerRotary.
1774
1775       ModemAnswerDialCmd
1776              The  command to explicitly answer the phone for a dialed connec‐
1777              tion.  This command must generate a result string  that  identi‐
1778              fies  the  incoming call is from a facsimile modem.  If this pa‐
1779              rameter is not specified or is null, then the value of  ModemAn‐
1780              swerCmd is used instead.
1781
1782       ModemAnswerFaxBeginCmd
1783              The command to send to the modem once a facsimile connection has
1784              been established.
1785
1786       ModemAnswerFaxCmd
1787              The command to explicitly answer the phone for a facsimile  con‐
1788              nection.   This command must generate a result string that iden‐
1789              tifies the incoming call is from a facsimile modem.  If this pa‐
1790              rameter  is not specified or is null, then the value of ModemAn‐
1791              swerCmd is used instead.  See also AdaptiveAnswer and  AnswerRo‐
1792              tary.
1793
1794       ModemAnswerVoiceBeginCmd
1795              The  command  to  send  to the modem once a voice connection has
1796              been established.
1797
1798       ModemAnswerVoiceCmd
1799              The command to explicitly answer the phone for a  voice  connec‐
1800              tion.   This  command must generate a result string that identi‐
1801              fies the incoming call is for voice.  If this parameter  is  not
1802              specified  or  is null, then the value of ModemAnswerCmd is used
1803              instead.  See also AdaptiveAnswer and AnswerRotary.
1804
1805       ModemAnswerResponseTimeout
1806              The maximum time, in milliseconds, to wait for a  response  from
1807              the  modem after sending ModemAnswerCmd.  Note that you may want
1808              to shorten this value when using the server-based  adaptive  an‐
1809              swer strategy; see AdaptiveAnswer.
1810
1811       ModemATCmdDelay
1812              A  delay,  in milliseconds, that should be performed before each
1813              ``AT'' command string is sent to the modem.
1814
1815       ModemBaudRateDelay
1816              The amount of time, in milliseconds, to pause after setting  the
1817              baud rate on the serial line.  This is only needed for hosts and
1818              modems (such as USRs) where setting the serial  line  parameters
1819              does not take effect immediately.
1820
1821       ModemCEDCmd
1822              The  command to signal CED and raise the V.21 HDLC transmit car‐
1823              rier after a session has started.  This is used after  a  proce‐
1824              dure  interrupt.   Normally  this command is ``ATA'', but if the
1825              modem does not permit ``ATA'' after a session has started,  then
1826              ``AT+FTH=3'' should probably be used, instead.
1827
1828       ModemCNGCmd
1829              The  command to signal CNG and listen for V.21 HDLC after a ses‐
1830              sion has started.  This is used  after  a  procedure  interrupt.
1831              Normally this command is ``ATD'', but if the modem does not per‐
1832              mit ``ATD'' after  a  session  has  started,  then  ``AT+FRH=3''
1833              should probably be used, instead.
1834
1835       ModemCommaPauseTimeCmd
1836              The  command  to set the time, in seconds, that the modem should
1837              pause when encountering a ``,'' modifier in the dialing string.
1838
1839       ModemDialCmd
1840              The command to place a phone call.  The string is assumed to  be
1841              suitable  for use as a parameter to the sprintf(3S) function; so
1842              the ``%'' character should be escaped as ``%%''.  The dial  com‐
1843              mand must include a single ``%s'' where the number that is to be
1844              dialed is to be substituted.  The command may include  a  single
1845              ``%d'' where the origin number is to be substituted.  Facilities
1846              such as tone or pulse dialing, outgoing prefixes to route though
1847              a  PBX,  and  so  on  should  be included in the dialing command
1848              string.  It is also important  that,  if  possible,  a  trailing
1849              ``@'' symbol should be included so that the modem returns result
1850              codes that distinguish between no answer and no carrier.  Use of
1851              the  ``@''  permits  the server to reduce the probability that a
1852              wrong number is continually redialed.  If  the  modem  does  not
1853              support  this  facility,  then  it may be necessary to raise the
1854              number of retries done when a ``NO CARRIER'' result is returned.
1855
1856       ModemDialResponseTimeout
1857              The maximum time to wait, in milliseconds, for a  response  from
1858              the  modem  after  sending  This value should be longer than the
1859              timeout programmed into the modem through  the  ModemWaitTimeCmd
1860              parameter.   This additional server-based timeout is provided to
1861              guard against modems that can ``lock up'' when dialing the tele‐
1862              phone.
1863
1864       ModemDoPhaseCDebug
1865              Whether  or  not  to  query the modem for responses during image
1866              data transmission.  Normally the modem should  not  produce  any
1867              responses  during  Phase  C data transmission.  However, in some
1868              debugging scenarios (i.e. some Class 2.1 modems may show  debug‐
1869              ging  information)  it may be appropriate to query the modem for
1870              responses during the data transmission.
1871
1872       ModemDTRDropDelay
1873              The time, in milliseconds, to pause between placing DTR OFF  and
1874              DTR  ON  while resetting a modem.  This value should be at least
1875              equal to the time-value of  the  analogous  S-register,  usually
1876              S25.   This  so-called DTR drop can be bypassed entirely by set‐
1877              ting ModemDTRDropDelay to 0, but this should likely only be used
1878              for debugging purposes.
1879
1880       ModemEchoOffCmd
1881              The command to disable echoing of commands sent to the modem.
1882
1883       ModemFlowControl
1884              The  type  of  flow  control  to use between DTE and DCE; one of
1885              ``NONE'', ``XONXOFF'' and ``RTSCTS''.  This value is used to se‐
1886              lect the string sent to the modem to initially establish DTE-DCE
1887              flow  control;  one  of  ModemNoFlowCmd,  ModemSoftFlowCmd,  and
1888              ModemHardFlowCmd.  The current flow control setting is also used
1889              to select the appropriate flow control command to  send  to  the
1890              modem  when  the  software  switches  to Class 1, 2, or 2.0; see
1891              Class1HFLOCmd,  Class1NFLOCmd,   Class1SFLOCmd,   Class2HFLOCmd,
1892              Class2NFLOCmd, and Class2SFLOCmd.
1893
1894              The  server supports both software and hardware flow control for
1895              Class 1, Class 2, and Class 2.0 modems.  Whether to use hardware
1896              or  software flow control depends on the capabilities of the mo‐
1897              dem and the host hardware and operating  system.   Communication
1898              rates  above  9600 baud often require that hardware flow control
1899              be used for reliable  DTE-DCE  communication.   However,  beware
1900              that many modems only support software flow control when sending
1901              or receiving facsimile.
1902
1903              Note that modems usually support software flow control  even  if
1904              they have no explicit AT-command to activate it; in this case it
1905              is  switched  on  when  the  modem  enters  fax   mode,   having
1906              AT+FCLASS=... from DTE.
1907
1908       ModemFrameFillOrder
1909              The bit order to expect for received HDLC frames and to use when
1910              formulating HDLC frames to  send.   This  value  may  be  either
1911              LSB2MSB  when  bits  are  ordered  from least-significant-bit to
1912              most-significant-bit (as in the CCITT specification) or  MSB2LSB
1913              when bits are ordered in the reverse direction.
1914
1915       ModemHardFlowCmd
1916              The command to setup hardware (RTS/CTS) flow control between DTE
1917              and DCE.
1918
1919       ModemMinSpeed
1920              The minimum acceptable signalling rate for transmitting  facsim‐
1921              ile  page  data.   Possible  values are: 2400, 4800, 7200, 9600,
1922              12200, and 14400.
1923
1924       ModemMfrQueryCmd
1925              The command to send to the modem to get the manufacturer identi‐
1926              fication  string.  If this parameter is not set, then it is ini‐
1927              tialized to ``AT+FMFR?'' for Class 2 modems, or  to  ``AT+FMI?''
1928              for Class 2.0 modems, or to ``ATI3'' for Class 1 modems.  If the
1929              parameter begins with a ``!'', then the remainder of the  string
1930              is  taken  to be the identification string and no command is is‐
1931              sued to the modem.
1932
1933       ModemModelQueryCmd
1934              The command to send to the modem to get the model identification
1935              string.  If this parameter is not set, then it is initialized to
1936              to ``AT+FMDL?'' for Class 2 modems, or to ``AT+FMM?'' for  Class
1937              2.0 modems, or to ``ATI0'' for Class 1 modems.  If the parameter
1938              begins with a ``!'', then the remainder of the string  is  taken
1939              to  be the identification string and no command is issued to the
1940              modem.
1941
1942       ModemNoAutoAnswerCmd
1943              The command to stop the modem from automatically answering  when
1944              the phone rings.
1945
1946       ModemNoAutoAnswerCmdDelay
1947              The  time, in milliseconds, to pause after receiving the OK fol‐
1948              lowing ModemNoAutoAnswerCmd before any further commands are sent
1949              to  the  modem.  All input from the modem is flushed after paus‐
1950              ing.
1951
1952       ModemNoFlowCmd
1953              The command to disable flow control between DTE and DCE.
1954
1955       ModemOnHookCmd
1956              The command to place the phone ``on hook'' (i.e. hangup).
1957
1958       ModemPageDoneTimeout
1959              The maximum time to wait, in milliseconds, for a  response  from
1960              the modem after sending a page of facsimile data (e.g.  the time
1961              to wait for a response to a Class 2/2.0 AT+FET command).
1962
1963       ModemPageStartTimeout
1964              The maximum time to wait, in milliseconds, for  an  initial  re‐
1965              sponse  from  the  modem  when  sending a page of facsimile data
1966              (e.g. the time to wait for a response to a  Class  2/2.0  AT+FDR
1967              command).
1968
1969       ModemRaiseATCommands
1970              Indicates  whether  or not all configuration AT commands for the
1971              modem should be raised to upper-case automatically.   The  stan‐
1972              dard  is  for  all upper-case to be used in AT commands, and in‐
1973              deed, some rare modems  have  been  known  to  malfunction  with
1974              lower-case  commands.   However,  sometimes an administrator may
1975              want to use lower-case commands in a rare condition such  as  to
1976              work around modem blacklisting of dialed numbers.
1977
1978       ModemRate
1979              The  baud rate to use for DCE-DTE communication.  This value may
1980              be one of: 115200, 76800, 57600, 38400, 19200, 9600, 4800, 2400,
1981              1200.   The  default value is 19200 because many modems lock the
1982              rate at 19200 when sending or receiving  facsimile.   Note  that
1983              not  all  values  are  supported  by  all  operating systems and
1984              modems; consult stty(1) for the available rates on your system.
1985
1986       ModemReadyCmds
1987              A string of commands to issue to the modem during reception ini‐
1988              tialization.   This  string is sent to the modem after the stan‐
1989              dard set of configuration commands required by the  fax  server.
1990              This  is  done, for example, to un-busy a DID line so that calls
1991              can come through.
1992
1993       ModemRecvFillOrder
1994              The bit order to expect for received facsimile data.  This value
1995              may  be either LSB2MSB when bits are ordered from least-signifi‐
1996              cant-bit to most-significant-bit (as in the CCITT specification)
1997              or  MSB2LSB when bits are ordered in the reverse direction.  Ac‐
1998              cording to the various specifications all modems  should  return
1999              data  in  LSB2MSB  order.   However  most Class 2 modems (except
2000              maybe only Multitech) use MSB2LSB for compatibility with  modems
2001              that  were built with Rockwell hardware/firmware that included a
2002              bug that was too widespread to correct.
2003
2004              If this parameter is not set, then it is autodetected and set to
2005              LSB2MSB  for  Class  1 and Class 2.0 modems and MSB2LSB for non-
2006              Multitech Class 2 modems. However this may be wrong for your mo‐
2007              dem, so you will have to specify this parameter explicitly.
2008
2009       ModemRecvSuccessCmd
2010              A  string  of  commands to issue to the modem after a successful
2011              receive session before the call is disconnected.
2012
2013       ModemResetCmds
2014              A string of commands to issue to the  modem  during  initializa‐
2015              tion.   This string is sent to the modem before the standard set
2016              of configuration commands required by the fax server.  Note that
2017              these commands should not include normal reset commands that are
2018              specified through other parameters.  For  example,  commands  to
2019              setup  flow  control, DCD handling, DTR handling, etc. should be
2020              specified through the appropriate configuration  parameters  and
2021              not  through this parameter.  In addition the soft reset command
2022              (usually ``ATZ'') should not be included  in  this  string;  the
2023              servers issue this command explicitly.
2024
2025       ModemResetDelay
2026              The  time, in milliseconds, to pause after setting DTR ON, while
2027              resetting a modem.  DTR ON does not respond with ``OK'', so this
2028              parameter  should  be  long enough to allow the modem time to be
2029              ready for ModemSoftResetCmd successively.
2030
2031       ModemResultCodesCmd
2032              The command to enable result codes.
2033
2034       ModemRevQueryCmd
2035              The command to send to the modem  to  get  a  firmware  revision
2036              identification string.  If this parameter is not set, then it is
2037              initialized  to  ``AT+FREV?''  for  Class  2   modems,   or   to
2038              ``AT+FMR?''  for Class 2.0 modems.  If the parameter begins with
2039              a ``!'', then the remainder of the string is  taken  to  be  the
2040              identification string and no command is issued to the modem.
2041
2042       ModemSecondAnswerCmd
2043              The command to send to the modem in the event that the first an‐
2044              swer command results with ``OK'' rather than  an  otherwise  ex‐
2045              pected  indication.   This command is intended to resume the an‐
2046              swer procedure where the first left off.
2047
2048       ModemSendBeginCmd
2049              The command to send to the modem upon establishing carrier  dur‐
2050              ing  a transmit operation.  This parameter is useful for systems
2051              that are incapable of enabling hardware flow control without DCD
2052              asserted.
2053
2054       ModemSendFillOrder
2055              The  bit order the modem expects for transmitted facsimile data.
2056              This value may be either LSB2MSB or MSB2LSB (see also ModemRecv‐
2057              FillOrder  above.)  Virtually all modems expect transmitted fac‐
2058              simile data in LSB2MSB bit order.
2059
2060       ModemSetOriginCmd
2061              The command to use to set the  call  origin  information  before
2062              placing  a  call.  The command may include a single ``%d'' where
2063              the job request ``faxnumber'' string is to be substituted.   The
2064              command  may  also include a single ``%s'' where the job request
2065              ``faxname'' string is to be subsituted.
2066
2067       ModemSetVolumeCmd
2068              The commands to use to set  the  modem  speaker  volume  levels.
2069              There should be five whitespace-separated commands, one each for
2070              setting the volume to ``Off'', ``Quiet'',  ``Low'',  ``Medium'',
2071              and  ``High'';  the  default  is  ``"ATM0  ATL0M1  ATL1M1 ATL2M1
2072              ATL3M1"''.  See also SpeakerVolume.
2073
2074       ModemSetupAACmd
2075              The command to setup adaptive answer  support  in  the  modem-if
2076              available.   Adaptive answer is the term used for the ability to
2077              distinguish  between  calls  from  facsimile,  voice,  and  data
2078              sources.   Note  that  this string is the last command issued by
2079              the device drivers during setup, so the command string  may,  if
2080              necessary,  switch  to  a different operating mode (e.g. on some
2081              Rockwell-based modems it is necessary to issue the  ``AT+FAA=1''
2082              command in Class 0).
2083
2084       ModemSetupDCDCmd
2085              The  command to setup DCD handling.  On most systems the facsim‐
2086              ile server will enable the CLOCAL flag  on  the  tty  device  to
2087              which  the modem is connected.  This should ensure that the sys‐
2088              tem does not close an open file descriptor associated  with  the
2089              modem  if carrier is dropped.  Thus, for most systems and modems
2090              ModemSetupDCDCmd should setup DCD to reflect carrier.
2091
2092       ModemSetupDTRCmd
2093              The command to setup DTR handling so that  the  modem  is  reset
2094              when  the  DTR  signal  is  lowered  by the host.  The facsimile
2095              server uses this facility to ensure that modems are not left  in
2096              a ``locked up'' state.
2097
2098       ModemSoftFlowCmd
2099              The  command  to  setup software (XON/XOFF) flow control between
2100              DTE and DCE.
2101
2102       ModemSoftResetCmd
2103              The command to force a soft reset of the modem.
2104
2105       ModemSoftResetCmdDelay
2106              The time, in milliseconds, to pause after receiving the OK  fol‐
2107              lowing ModemSoftResetCmd before any further commands are sent to
2108              the modem.
2109
2110       ModemSoftRTFCC
2111              Whether or not to enable software-driven Real-Time Fax  Compres‐
2112              sion Conversion.  RTFCC allows HylaFAX to convert the image com‐
2113              pression between MH MR and MMR formats regardless  of  how  faxq
2114              formatted  the image file.  Note that when using RTFCC, the com‐
2115              pression format of the file will be ignored,  thus  the  ``-1'',
2116              ``-2'',  and ``-3'' options for sendfax, ps2fax, and others will
2117              only influence how the document is prepared by faxq and will not
2118              influence the actual negotiated session parameters.  Class2RTFCC
2119              takes precedence over ModemSoftRTFCC and if  both  are  enabled,
2120              then software-driven RTFCC will not be performed in favor of the
2121              firmware-driven RTFCC.
2122
2123       ModemType
2124              This parameter must be set to one of: ``Class2'',  ``Class2.0'',
2125              ``Class1'',  or  ``Class1.0'';  to  indicate that the modem is a
2126              Class 2-, Class 2.0-, Class 1-, or Class  1.0-style  modem,  re‐
2127              spectively.   If this parameter is not set, then HylaFAX detects
2128              which classes are supported by the modem and makes  an  internal
2129              decision  on  which  to use.  Historically this decision chooses
2130              Class 2.1 over Class 2.0 over Class 2 over Class 1.0 over  Class
2131              1.  However, some exceptions are made, for instance, with US Ro‐
2132              botics modems where Class 2.0 support is avoided.
2133
2134       ModemVerboseResultsCmd
2135              The command to enable verbose, as  opposed  to  numeric,  result
2136              codes.
2137
2138       ModemWaitForConnect
2139              If  enabled, the facsimile server will not consider a connection
2140              established when answering an incoming call until a  ``CONNECT''
2141              status  string  is received.  This is useful mainly for Rockwell
2142              RC32ACL-based modems that send ``FAX'' and ``DATA'' status  mes‐
2143              sages before sending ``CONNECT''.
2144
2145       ModemWaitTimeCmd
2146              The  command  to set the number of seconds to wait for a carrier
2147              signal when placing a call or answering the phone.
2148

T.30 PROTOCOL CONFIGURATION PARAMETERS

2150       The following parameters apply to the implementation of the CCITT  T.30
2151       facsimile  protocol  in  the Class 1 device driver.  They should not be
2152       changed without full understanding of the operation of the server.
2153
2154       FaxT1Timer
2155              The value of the T1 timer in milliseconds.  This timer  is  used
2156              to  time  out  the  initial  session  contact;  i.e.  receipt of
2157              DIS/DCS.
2158
2159       FaxT2Timer
2160              The value of the T2 timer in milliseconds.  This timer  is  used
2161              to time out receiving responses and commands.
2162
2163       FaxT4Timer
2164              The  value  of the T4 timer in milliseconds.  This timer is used
2165              to time out the reception of HDLC frames and,  usually,  trigger
2166              frame retransmissions.
2167

CLASS 1 MODEM CONFIGURATION PARAMETERS

2169       The  following  parameters  are  specific to the configuration of Class
2170       1-style modems; they should not be changed lightly:
2171
2172       Class1Cmd
2173              The command to set the modem into Class 1 operation.
2174
2175       Class1AdaptRecvCmd
2176              The command used to enable adaptive reception  support  (usually
2177              ``AT+FAR=1'').   This  feature  is  new in T.31, and many modems
2178              will not support it.  This feature may reduce the number of  re‐
2179              ception failures due to errors cascading from +FCERROR messages.
2180
2181       Class10AutoFallback
2182              Whether  or not the modem implements an automatic fallback to G3
2183              mode if V.8 handshaking ANSam is not detected for  a  Class  1.0
2184              V.34-Fax (SuperG3) call.
2185
2186       Class1ColorJPEGSupport
2187              Whether or not to enable support for T.30-E full-color facsimile
2188              with JPEG  compression.   Enabling  this  automatically  enables
2189              Class1GreyJPEGSupport.
2190
2191       Class1EnableV34Cmd
2192              The command to enable V.34-fax support with at least the desired
2193              maximum primary channel rate.
2194
2195       Class1ECMCheckFrameLength
2196              Whether or not to require the frame length for ECM  data  frames
2197              to be complete when checking for frame integrity.  Normally this
2198              is not beneficial (and can be problematic for some senders), but
2199              in some cases the frame CRC is not reliable because of modem be‐
2200              havior.
2201
2202       Class1ECMSupport
2203              Whether or not to support T.30-A error correction protocol.  Use
2204              of ECM will require 64 kilobytes of free memory per modem in ac‐
2205              tive use.
2206
2207       Class1PersistentECM
2208              Whether or not to continue to retransmit and allow  to  continue
2209              to  receive  image data in ECM protocol which is not accepted as
2210              valid after four successive attempts.
2211
2212       Class1ECMFrameSize
2213              The size in bytes of image frames to transmit during ECM  proto‐
2214              col.   This  setting  will also indicate a preference in receive
2215              sessions.  The only acceptable values are 64 and 256.  A setting
2216              of  64  may be useful on high-load systems and possibly environ‐
2217              ments with extremely poor line quality.
2218
2219       Class1ExtendedRes
2220              Whether or not to support  resolutions  other  than  normal  and
2221              fine.  This option has been deprecated by Class1Resolutions.
2222
2223       Class1FrameOverhead
2224              The  number  of extraneous bytes in HDLC frames sent to the host
2225              in response to an ``AT+FRH'' command.  For modems that  properly
2226              implement  the  Class  1 interface, this number should be 4 (the
2227              default).
2228
2229       Class1GreyJPEGSupport
2230              Whether or not to enable support for T.30-E greyscale  facsimile
2231              with  JPEG  compression.  This is always enabled if Class1Color‐
2232              JPEGSupport is enabled.
2233
2234       Class1HookSensitivity
2235              The number of times to  ignore  on-hook  detections  and  merely
2236              treat them as command or modem errors.
2237
2238       Class1JBIGSupport
2239              Whether  or  not to enable support for T.85 monochrome facsimile
2240              with JBIG compression.  Options are ``true'' for support in both
2241              sending  and  receiving,  ``false'' for no support, ``send'' for
2242              support only in sending, and ``receive'' for support only in re‐
2243              ceiving.  If, during the build process a compatible JBIG library
2244              was found then send support is enabled by default.   If,  during
2245              the  build process the TIFF tools are found to support JBIG then
2246              receive support is enabled by default.
2247
2248       Class1MRSupport
2249              Whether or not to enable support  for  two-dimensional  Modified
2250              Read (MR) image data format compression.
2251
2252       Class1MMRSupport
2253              Whether  or  not  to enable support for two-dimensional Modified
2254              Modified Read (MMR) image data format  compression.   Note  that
2255              MMR support requires also ECM support to be enabled.
2256
2257       Class1HasRHConnectBug
2258              A  Class  1 modem should only report CONNECT after AT+FRH=3 when
2259              V.21 HDLC data is detected.  However, some  modems  will  incor‐
2260              rectly  report  CONNECT  after  AT+FRH=3 whenever any carrier is
2261              present. In such cases Class1HasRHConnectBug should  be  set  to
2262              ``true''.
2263
2264       Class1HasRMHookIndication
2265              A  Class  1 modem should result ERROR after AT+FRM=<mod> when it
2266              is on hook.  However, some modems will incorrectly use ERROR re‐
2267              port  a  carrier  detection  mismatch.  In such cases Class1Has‐
2268              RMHookIndication should be set to ``false''.
2269
2270       Class1HFLOCmd
2271              The command to setup hardware (RTS/CTS) flow control between DTE
2272              and DCE when operating in Class 1.  This command is issued imme‐
2273              diately after sending the Class1Cmd to switch the modem to Class
2274              1 operation.
2275
2276       Class1NFLOCmd
2277              The  command  to  setup no flow control between DTE and DCE when
2278              operating in Class 1.  This command is issued immediately  after
2279              sending the Class1Cmd to switch the modem to Class 1 operation.
2280
2281       Class1PageLengthSupport
2282              The  coded  value  for page lengths supported by the modem.  The
2283              only correct values and  meanings  are  these:  ``1'',  A4  page
2284              length; ``3'', both A4 and B4 page length; ``7'', unlimited page
2285              length.
2286
2287       Class1PageWidthSupport
2288              The coded value for page widths supported  by  the  modem.   The
2289              only  correct  values  and  meanings  are  these: ``1'', A4 page
2290              width; ``3'', both A4 and B4 page width; ``7'', all of  A4,  B4,
2291              and A3 page widths.
2292
2293       Class1PPMWaitCmd
2294              The  command  used to stop and wait before sending the post page
2295              message, except before sending  EOP,  when  Class1EOPWaitCmd  is
2296              used  instead.   We  must ensure that the high-speed carrier has
2297              stopped completely.  According to T.30, Chapter 5, Note 4,  this
2298              delay should be 75 +/- 20 ms.
2299
2300       Class1ResponseWaitCmd
2301              The  command used to stop and wait after sending TCF, before at‐
2302              tempting to receive a training response from  the  remote.   Set
2303              this  to  ``AT+FTS=1'' if the modem responds ``OK'' before actu‐
2304              ally dropping the high-speed TCF carrier.
2305
2306       Class1Resolutions
2307              A bitmapped (bit-or'd) value indicating the  resolutions  to  be
2308              supported  during  facsimile  operation.  Individual resolutions
2309              follow Table 21/T.32 and are defined as follows:
2310              Bit              Description
2311              0 (0x00)         R8 x 3.85 l/mm, Normal
2312              1 (0x01)         R8 x 7.7 l/mm, Fine
2313              2 (0x02)         R8 x 15.4 l/mm, Superfine
2314              4 (0x04)         R16 x 15.4 l/mm, Hyperfine
2315              8 (0x08)         200 dpi x 100 l/inch
2316              16 (0x10)        200 dpi x 200 l/inch
2317              32 (0x20)        200 dpi x 400 l/inch
2318              64 (0x40)        300 dpi x 300 l/inch
2319              Thus, a value of 3 would indicate support for normal, fine,  and
2320              superfine resolutions.
2321
2322       Class1RMQueryCmd
2323              The  command  to  send to the modem to get the list of supported
2324              reception bit-rates.  If the parameter begins with a ``!'', then
2325              the  remainder  of  the string is taken to be the modem response
2326              and no command is issued to the modem.
2327
2328       Class1TCFWaitCmd
2329              The command used to stop and wait before sending TCF, similar to
2330              Class1PPMWaitCmd.   According  to  T.30, Chapter 5, Note 3, this
2331              delay should be 75 +/- 20 ms.
2332
2333       Class1TMQueryCmd
2334              The command to send to the modem to get the  list  of  supported
2335              transmission  bit-rates.   If the parameter begins with a ``!'',
2336              then the remainder of the string is taken to be  the  modem  re‐
2337              sponse and no command is issued to the modem.
2338
2339       Class1EOPWaitCmd
2340              The  command  used to stop and wait before sending the post page
2341              message similar to Class1PPMWaitCmd.  We allow a different  set‐
2342              ting  in  the case of EOP, however, because empirically some ma‐
2343              chines may need more time.
2344
2345       Class1ModemHasDLEBug
2346              Used to indicate that the modem does not correctly duplicate DLE
2347              characters in the V.21 communication to the DTE.
2348
2349       Class1MsgRecvHackCmd
2350              If  receive  failures  occur due to +FCERROR just prior to image
2351              data reception, setting  Class1MsgRecvHackCmd  to  AT+FRS=1  may
2352              help.
2353
2354       Class1RecvAbortOK
2355              The  time,  in  milliseconds,  to wait for an ``OK'' result code
2356              from  the  modem  after   aborting   an   HDLC   frame   receive
2357              (``AT+FRH=3'').   If  this number is zero, then the modem is as‐
2358              sumed to not correctly implement aborting and instead the driver
2359              will  wait  200ms,  flush  any input, and then send ``AT\n'' and
2360              wait 100ms for an ``OK'' result.
2361
2362       Class1RecvIdentTimer
2363              The time, in milliseconds, to wait for an initial DCS  when  re‐
2364              ceiving  a  facsimile.  CCITT recommendation T.30 specifies this
2365              as the value of  the  T1  timer.   However,  adaptive  answering
2366              schemes  such  as  that described above under the AdaptiveAnswer
2367              parameter may require that this timer be shortened.
2368
2369       Class1RestrictPoorDestinations¹
2370              The threshold of destination audio quality corruption  at  which
2371              resolution  support should be restricted to ``normal'' and color
2372              support should be disabled.  This  is  intended  to  reduce  the
2373              amount of image data that will be attempted to be sent to a des‐
2374              tination with poor audio quality, thus reducing the  call  dura‐
2375              tion,  and  should  improve the likelihood of successful session
2376              completion.  The threshold is the ratio, expressed as an integer
2377              percentage, of data indicated as corrupt by the destination com‐
2378              pared to total data sent to  the  destination  in  the  previous
2379              three  fax sessions.  Although Class1RestrictPoorDestinations is
2380              functional for destinations with a history of both ECM and  non-
2381              ECM  sessions, the ECM session history is preferred and weighted
2382              considerably higher than non-ECM session history.
2383
2384       Class1RestrictPoorSenders
2385              The threshold of sender audio quality corruption at which  reso‐
2386              lution support should be restricted to ``normal'' and color sup‐
2387              port should be disabled.  This is intended to reduce the  amount
2388              of image data that a sender with poor audio quality will attempt
2389              to transmit, thus reducing the call duration, and should improve
2390              the  likelihood of successful session completion.  The threshold
2391              is the ratio, expressed as an  integer  percentage,  of  corrupt
2392              data  received  compared to total data received from the current
2393              sender in the previous three fax sessions.  Class1RestrictPoorS‐
2394              enders  requires that a CallIDType of ``calling-number'' be con‐
2395              figured in order to match a sender with an  entry  in  the  info
2396              database.
2397
2398       Class1RMPersistence
2399              The  number  of  times that an attempt to receive the high-speed
2400              data carrier should be made, resulting in +FCERROR,  before  the
2401              low-speed  message  carrier reception is attempted.  Some modems
2402              are quick to (perhaps  incorrectly)  return  +FCERROR,  and  for
2403              those  modems a value of 2 or 3 should be used.  For modems that
2404              are not quick to return +FCERROR, a value of 1 should  be  used.
2405              Proper  tuning of this can provide a type of "adaptive reception
2406              control" for modems that accurately return +FCERROR without sup‐
2407              porting  Class1AdaptRecvCmd.   For  those  modems  that  support
2408              Class1AdaptRecvCmd, Class1RMPersistence should probably  not  be
2409              set  at 1, although +FCERROR should almost never occur with such
2410              modems.
2411
2412              If the modem does not support the reporting of +FCERROR or adap‐
2413              tive reception control, then Class1RMPersistence should probably
2414              be set at 0, which causes the timeout looking for the high-speed
2415              data  carrier to be shortened, thus increasing the likelihood of
2416              recovery from any dissynchronization.  When  Class1RMPersistence
2417              is  other  than  0  it is assumed that the +FCERROR reporting or
2418              Class1AdaptRecvCmd is functional and therefore the timeout look‐
2419              ing for the high-speed data carrier is lengthened.
2420
2421       Class1SwitchingCmd
2422              The command used to ensure that the sending facsimile device has
2423              turned off its modulator (i.e. loss-of-carrier)  as  recommended
2424              by T.31: Appendix II.1.
2425
2426       Class1SFLOCmd
2427              The  command  to  setup software (XON/XOFF) flow control between
2428              DTE and DCE when operating in Class 1.  This command  is  issued
2429              immediately  after  sending the Class1Cmd to switch the modem to
2430              Class 1 operation.
2431
2432       Class1SSLFaxCert
2433              The relative path to the PEM certificate file for SSL  Fax  use.
2434              This is normally created by faxsetup(8C).
2435
2436       Class1SSLFaxClientTimeout
2437              The  time,  in milliseconds, that the SSL Fax server should wait
2438              for the client connection to complete before abandoning SSL  Fax
2439              and proceeding with a traditional fax operation.
2440
2441       Class1SSLFaxInfo
2442              The  formatted  hostname  and port number for SSL Fax connection
2443              for this modem.  (Each modem should use a  different  port  num‐
2444              ber.)   This  instructs  the  remote  system  on  how to connect
2445              through the IP network to this system  as  an  SSL  Fax  server.
2446              Firewalling  and  port  forwarding should be carefully addressed
2447              prior to using this configuration.  The format for Class1SSLFax‐
2448              Info  is ``<hostname>:<port>''.  During fax protocol this infor‐
2449              mation will be made into  a  URL  by  prepending  ``ssl://<pass‐
2450              code>@'' and communicated as part of CSA and TSA signals for SSL
2451              Fax.  (``<passcode>'' is a string of random characters.)
2452
2453              ``<hostname>'' may be specified as an IP  address;  however,  in
2454              such   cases  it  should  be  bracketed,  for  example:  ``[<ad‐
2455              dress>]:<port>''.  This prevents confusion, especially with IPv6
2456              addresses.
2457
2458              Either  the  sender or the receiver (or both) must signal an SSL
2459              Fax URL in order for SSL Fax to operate.  If no Class1SSLFaxInfo
2460              is configured for one system, then it is always dependent on the
2461              remote systems to operate as the SSL Fax server.
2462
2463       Class1SSLFaxServerTimeout
2464              The time, in milliseconds, that the SSL Fax client  should  wait
2465              for  the  connection to the server to complete before abandoning
2466              SSL Fax and proceeding with a traditional fax  operation.   Usu‐
2467              ally this must be shorter than 3 seconds.
2468
2469       Class1SSLFaxSupport
2470              Whether or not to enable SSL Fax support.
2471
2472       Class1TCFMaxNonZero
2473              The  maximum  percentage  of non-zero data bytes permitted in an
2474              acceptable received TCF.  Note that this number does not include
2475              any  leading  non-zero  data  in  the  received  data.  See also
2476              Class1TCFMinRun.
2477
2478       Class1TCFMinRun
2479              The duration, in milliseconds, of the minimum run of  zero  data
2480              in  an  acceptable received TCF.  This value should be specified
2481              according to a 1.5 second transmission of  zero  data  (i.e.  it
2482              should be between 0 and 1500).  See also Class1TCFMaxNonZero and
2483              Class1TCFMinRunECMMod.
2484
2485       Class1TCFMinRunECMMod
2486              The factor by which Class1TCFMinRun should be  modified  in  the
2487              case  of an ECM session.  As ECM protocol allows retransmissions
2488              it is commonly faster to accept a lesser-quality data stream and
2489              the  subsequent retransmisisons than it is to allow the communi‐
2490              cation speed to slow down (where the demodulation may still  not
2491              produce an ideal data stream, anyway).
2492
2493       Class1TCFRecvHackCmd
2494              If receive failures occur due to +FCERROR just prior to TCF data
2495              reception, setting Class1TCFRecvHackCmd to AT+FRS=1 may help.
2496
2497       Class1TCFRecvTimeout
2498              The maximum time to wait, in milliseconds, for  the  first  byte
2499              and  again  for the entirety of the Training Check (TCF) message
2500              data that is received during the training phase of the facsimile
2501              reception protocol.
2502
2503       Class1TMConnectDelay
2504              The time, in milliseconds, to delay after receiving CONNECT fol‐
2505              lowing +FTM before sending image data.  T.31 8.3.3 requires  the
2506              modem  to  respond  with  CONNECT before the modulation training
2507              pattern.  If the modem cannot buffer all of the data sent to  it
2508              before successful modulation training then data, especially dur‐
2509              ing TCF (as it is so short), could be lost.  Many modems reason‐
2510              ably  do not follow T.31 in this regard, and thus the default is
2511              zero; however its use with such modems would likely have a  neg‐
2512              ligible  effect.  When modems are used that can buffer data dur‐
2513              ing the training period then the default is also functional.
2514
2515              The modulator training time period varies by modulation and  bi‐
2516              trate.   V.17  fast  train  and V.29 both take less than 400 ms.
2517              However, V.27ter can take twice that long, and V.17  slow  train
2518              can  take  four times as long.  Thus, the early CONNECT stipula‐
2519              tion by T.31 8.3.3 becomes programmatically cumbersome  for  the
2520              DTE.
2521
2522              T.31  8.3.3  requires  the modem to transmit constant ones after
2523              modulator training completes and before the DTE  supplies  data.
2524              Therefore,  some  receivers  have  become  dependent on seeing a
2525              1-to-0 bit transition at the outset of Phase  C  ECM  data,  and
2526              such  an  expectation  for  TCF would also not be surprising (as
2527              both Phase C ECM and TCF involve predictable patterns).   There‐
2528              fore, when not using SSL Fax or SuperG3 V.34-Fax, HylaFAX trans‐
2529              mits a single byte of ones at the outset of both TCF and Phase C
2530              ECM  image data to ensure that there is a 1-to-0 bit transition.
2531              Such does not seem necessary at the outset of  non-ECM  Phase  C
2532              data as the data pattern is not so predictable and any data loss
2533              is likely to go unnoticed.
2534
2535       Class1ValidateV21Frames
2536              Whether or not to use the FCS bits of received V.21 HDLC  frames
2537              to  check the validity of the frame itself.  Most Class 1 modems
2538              perform this check independently (per T.31 7.4) and do  not  re‐
2539              quire this feature to be enabled.
2540

CLASS 2 AND 2.0 MODEM CONFIGURATION PARAMETERS

2542       The  following parameters are specific to the configuration of Class 2-
2543       and Class 2.0-style modems:
2544
2545       Class2Cmd
2546              The command to set the modem into Class 2/2.0 operation.
2547
2548       Class2AbortCmd
2549              The command to use to abort an established session.  After using
2550              this  command  to  abort  a  session, the fax software will send
2551              ModemOnHookCmd and then reset the modem by dropping DTR .
2552
2553       Class2APCmd
2554              A largely unused option for modems  supporting  ITU-T.32,  Class
2555              2.1,  standards.   This  command would be used to enable sending
2556              and receiving SUB, SEP, and PWD frames.
2557
2558       Class2APQueryCmd
2559              A largely unused option for modems  supporting  ITU-T.32,  Class
2560              2.1,  standards.   This command would be used to query the capa‐
2561              bilities of sending and receiving SUB, SEP, and PWD frames.  The
2562              value  ``none''  may  be  used if the modem does not support any
2563              Class2APQueryCmd.
2564
2565       Class2BORCmd
2566              The command to setup the bit order of sent and received  facsim‐
2567              ile  data.   Usually  the  command ``AT+FBOR=0'' is used so that
2568              data is sent and received in direct bit order  (LSB2MSB).   Some
2569              modems,  such  as the Everex 24/96D, must use reversed bit order
2570              for Phase B and D data exchanges to avoid a bug that results  in
2571              garbage  data being placed in the padding of EOL codes.  The bit
2572              order specified by this command must correspond to the  settings
2573              of the ModemSendFillOrder and ModemRecvFillOrder parameters.
2574
2575       Class2BUGCmd
2576              The  command  to  use  to  enable or disable the tracing of HDLC
2577              frames sent and received by the modem.  This tracing information
2578              should be returned to the host in ``+FHR:'' and ``+FHT:'' status
2579              strings.  Note that many Class 2 modems do not support this  fa‐
2580              cility,  which  is  largely  used  for diagnostic purposes.  The
2581              value ``none'' may be used if the modem  does  not  support  any
2582              Class2BUGCmd.
2583
2584       Class2CIGCmd
2585              The  command  used  to set a polling identifier.  This string is
2586              inserted into the format ``%s="<id>"''.
2587
2588       Class2CQCmd
2589              The command to use to set up parameters for copy quality  check‐
2590              ing.   For  example,  for  an Everex 24/96D modem this parameter
2591              might  be  set  to   ``AT+FCQ=1\nAT+FBADMUL=20\nAT+FBADLIN=10''.
2592              Class2CQCmd  should  be  configured to set-up all available copy
2593              quality services available  per  Class2CQQueryCmd.   To  disable
2594              features  that  are available, configure Class2CQQueryCmd with a
2595              ``!'', and then set Class2CQCmd accordingly.
2596
2597       Class2CQQueryCmd
2598              The command to send to the modem to get the copy  quality  capa‐
2599              bilities string.  If the parameter begins with a ``!'', then the
2600              remainder of the string is taken to be the  capabilities  string
2601              and no command is issued to the modem; this can be used together
2602              with the Class2CQCmd to force copy quality checking to  be  done
2603              in  the  server  instead of in the modem.  See also PercentGood‐
2604              Lines and  MaxConsecutiveBadLines  for  parameters  used  to  do
2605              server  copy quality checking.  If copy quality checking is con‐
2606              figured to be done by the modem then  it  is  not  done  by  the
2607              server.
2608
2609       Class2CRCmd
2610              The command to use to enable the reception of facsimile.
2611
2612       Class2DCCCmd
2613              The  command used to set modem capabilities.  This string is in‐
2614              serted into the format ``%s=vr,br,wd,ln,df,ec,bf,st''.
2615
2616       Class2DCCQueryCmd
2617              The command to send to the modem to get the Class 2/2.0 capabil‐
2618              ities.  If the parameter begins with a ``!'', then the remainder
2619              of the string is taken to be the capabilities string and no com‐
2620              mand is issued to the modem.
2621
2622       Class2DDISCmd
2623              The  command  to  set  session  parameters before dialing.  This
2624              string       is       inserted       into       the       format
2625              ``%s=vr,br,wd,ln,df,ec,bf,st''.   Setting this parameter enables
2626              support for Class 2 modems that do not  properly  implement  the
2627              ``AT+FDIS''  command by setting up session parameters before di‐
2628              aling the telephone.
2629
2630       Class2DISCmd
2631              The command used to set the current  session  parameters.   This
2632              string       is       inserted       into       the       format
2633              ``%s=vr,br,wd,ln,df,ec,bf,st''.
2634
2635       Class2ECMType
2636              The interpretation of the EC parameter in the modem DCC response
2637              varies between the Class 2, ``2'', and Class 2.0, ``2.0'', spec‐
2638              ifications.  This configuration parameter allows the administra‐
2639              tor  to specify which type to use.  The corresponding specifica‐
2640              tion type is used by default.
2641
2642       Class2HexNSF
2643              Whether or not to parse the NSF strings reported  by  the  modem
2644              using  hexadecimal values.  By default, they are parsed as hexa‐
2645              decimal values.
2646
2647       Class2HFLOCmd
2648              The command to setup hardware (RTS/CTS) flow control between DTE
2649              and  DCE  when operating in Class 2/2.0.  This command is issued
2650              immediately after sending the Class2Cmd to switch the  modem  to
2651              Class  2/2.0  operation.  For Class 2.0 operation the default is
2652              ``AT+FLO=2''.
2653
2654       Class2JBIGSupport
2655              Whether or not to enable support for T.85  monochrome  facsimile
2656              with JBIG compression.  Options are ``true'' for support in both
2657              sending and receiving, ``false'' for no  support,  ``send''  for
2658              support only in sending, and ``receive'' for support only in re‐
2659              ceiving.  If the modem  supports  JBIG,  and  during  the  build
2660              process a compatible JBIG library was found then send support is
2661              enabled by default.  If the modem supports JBIG, and during  the
2662              build  process the TIFF tools are found to support JBIG then re‐
2663              ceive support is enabled by default.
2664
2665       Class2JPEGSupport
2666              Whether or not to enable and utilize the JPEG support  found  in
2667              the modem.
2668
2669       Class2LIDCmd
2670              The  command  used  to  set  the  local identifier string.  This
2671              string is inserted into the format ``%s="<id>"''
2672
2673       Class2MINSPCmd
2674              The command used to set the minimum acceptable speed to be nego‐
2675              tiated for transmitting page data.  This string is inserted into
2676              the format ``%s=<speed>''
2677
2678       Class2NFLOCmd
2679              The command to setup no flow control between DTE  and  DCE  when
2680              operating  in  Class  2/2.0.  This command is issued immediately
2681              after sending the Class2Cmd to switch the modem to Class 2 oper‐
2682              ation.  For Class 2.0 operation the default is ``AT+FLO=0''.
2683
2684       Class2NRCmd
2685              (Class  2.0  only)  The command to setup negotiation message re‐
2686              porting.  For the correct operation of the Class 2.0 driver this
2687              command  must  enable  the  reporting  of:  receiver parameters,
2688              transmitter parameters, and ID strings.  It is not necessary  to
2689              enable reporting of non-standard frames for correct operation of
2690              the Class 2.0 driver.
2691
2692       Class2PACmd
2693              A largely unused option for modems  supporting  ITU-T.32,  Class
2694              2.1,  standards.   This  command  would  be  used  to set up the
2695              polling address string enabled by the Class2APCmd.
2696
2697       Class2PHCTOCmd
2698              The command to use to set the Phase C timeout parameter (in sec‐
2699              onds).   The  value  ``none''  may be used if the modem does not
2700              support any Class2PHCTOCmd.
2701
2702       Class2PIECmd
2703              (Class 2.0 only) The command to use to control procedure  inter‐
2704              rupt  handling.  Procedure interrupts should be disabled because
2705              HylaFAX does not provide a mechanism for  dispatching  procedure
2706              interrupts to an administrator.
2707
2708       Class2PTSCmd
2709              The  command  to use to set the received page status code.  When
2710              copy quality checking is done in the host, this command  may  be
2711              used  to control the post-page response delivered to the sender.
2712              Beware that some modems do not properly implement  this  command
2713              in  which  case  the  server should be configured to not do copy
2714              quality check: see the PercentGoodLines  and  MaxConsecutiveBad‐
2715              Lines parameters to understand how to defeat copy quality check‐
2716              ing.
2717
2718       Class2PTSQueryCmd
2719              The command to use to query the received page status code.  This
2720              command may be used to determine the post-page response returned
2721              from the receiver.  Beware that some modems do not properly  im‐
2722              plement this command in which case this setting should be set to
2723              ``none''.
2724
2725       Class2PWCmd
2726              A largely unused option for modems  supporting  ITU-T.32,  Class
2727              2.1,  standards.  This command would be used to set up the pass‐
2728              word string enabled by the Class2APCmd.
2729
2730       Class2RecvDataTrigger
2731              The character to send to the modem to trigger  the  transmission
2732              of  received data from the modem to the host.  This character is
2733              specified to be DC1 (octal 21) in the draft specification 2388-A
2734              and  DC2  (octal  22) in the 2388-B specification.  Most Class 2
2735              modems accept DC1 or both DC1 and DC2.  Some modems however only
2736              accept  DC2.  Note that string parameters may use C-style escape
2737              sequences,  so  DC2,  for  example,  would   be   specified   as
2738              ``"\022"''.
2739
2740       Class2RELCmd
2741              The  command  to  use to enable the delivery of byte-aligned EOL
2742              codes in received facsimile.  If this parameter is defined, then
2743              received  facsimile  data  will  be  marked to indicate that EOL
2744              codes are byte-aligned; otherwise they will  be  marked  as  not
2745              (necessarily) having byte-aligned codes.
2746
2747       Class2RTFCC
2748              Whether  or  not to enable MultiTech's Real-Time Fax Compression
2749              Conversion which is available in later  firmware  revisions  for
2750              the  MT5634ZBA-V92,  MT5634ZPX-PCI-V92, and other models.  RTFCC
2751              allows HylaFAX to convert the image compression  between  MH  MR
2752              and MMR formats regardless of how faxq formatted the image file.
2753              If RTFCC is available with your firmware, then the  response  to
2754              ``AT+FFC=?''  is non-zero.  Note that when using RTFCC, the com‐
2755              pression format of the file will be ignored,  thus  the  ``-1'',
2756              ``-2'',  and ``-3'' options for sendfax, ps2fax, and others will
2757              not influence the actual negotiated session parameters.
2758
2759       Class2SACmd
2760              A largely unused option for modems  supporting  ITU-T.32,  Class
2761              2.1, standards.  This command would be used to set up the desti‐
2762              nation subaddress string enabled by the Class2APCmd.
2763
2764       Class2SendRTC
2765              Whether or not to append an explicit ``Return To Control'' (RTC)
2766              signal  to  the  page  data  when transmitting.  The Class 2 and
2767              Class 2.0 specs (i.e. SP-2388-A and TIA/EIA-592) state that  the
2768              modem  will  append  RTC  when it receives the post-page message
2769              command from the host; this parameter is provided  in  case  the
2770              modem does not correctly implement this.
2771
2772       Class2SFLOCmd
2773              The  command  to  setup software (XON/XOFF) flow control between
2774              DTE and DCE when operating in Class 2/2.0.  This command is  is‐
2775              sued immediately after sending the Class2Cmd to switch the modem
2776              to Class 2/2.0 operation.  For Class 2.0 operation  the  default
2777              is ``AT+FLO=1''.
2778
2779       Class2SPLCmd
2780              The  command  to  use  to  enable  a polling request.  The value
2781              ``none''  may  be  used  if  the  modem  does  not  support  any
2782              Class2SPLCmd.
2783
2784       Class2TBCCmd
2785              The  command  to use to enable stream-mode communication between
2786              the host and modem.  The value ``none'' may be used if the modem
2787              does not support any Class2TBCCmd.
2788
2789       Class2UseLineCount
2790              Whether  or not to use the line count reported to HylaFAX by the
2791              modem firmware decoder.
2792
2793       Class2UseHex
2794              Whether or not to parse the capabilities strings reported by the
2795              modem  using hexadecimal values.  By default, they are parsed as
2796              decimal values.
2797
2798       Class2XmitWaitForXON
2799              Whether or not to wait for an XON character from the  modem  be‐
2800              fore sending facsimile data to the modem for transmission.  Note
2801              that this is only relevant for modems that conform to the  Class
2802              2  spec  (i.e.  SP-2388-A).   The Class 2.0 specification states
2803              that the host may transmit data immediately upon receiving  CON‐
2804              NECT and that no XON character will be sent to the host.
2805
2807       The  following  parameters are specific to the configuration and opera‐
2808       tion of the IXO/TAP and UCP support for sending pager messages and  GSM
2809       SM. Parameter not used for UCP are marked with ``(IXO/TAP only)''.
2810
2811       PagerSetupCmds
2812              The  commands to send to a modem to prepare the modem for a call
2813              to pager service provider.  Typically these commands  place  di‐
2814              rect  the  modem to communicate with the service provider at 300
2815              bps using  the  V.21  protocol.   Per-service  provider  command
2816              strings can be setup in the info database; see hylafax-info(5F).
2817
2818       PagerMaxMsgLength
2819              The  maximum  length  for a pager text message.  Messages longer
2820              than this number are truncated.   Per-service  provider  message
2821              lengths can be setup in the info database; see hylafax-info(5F).
2822
2823       IXOService
2824              (IXO/TAP  only) The service identification string transmitted as
2825              part of the IXO/TAP protocol.
2826
2827       IXODeviceID
2828              (IXO/TAP only) The terminal device identification string  trans‐
2829              mitted as part of the IXO/TAP protocol.
2830
2831       IXOMaxUnknown
2832              The  maximum  number  of  unrecognized messages that will be ac‐
2833              cepted at various stages of  the  IXO/TAP  protocol  before  the
2834              sender will abort and hang up the phone.
2835
2836       IXOIDProbe
2837              (IXO/TAP  only)  The  time, in seconds, between sending a ``\r''
2838              during the initial ID recognition sequence of the IXO/TAP proto‐
2839              col.
2840
2841       IXOIDTimeout
2842              (IXO/TAP  only)  The  maximum  time, in seconds, to wait for the
2843              initial ID response from the service provider.
2844
2845       IXOLoginRetries
2846              (IXO/TAP only) The maximum number of attempts to login to a ser‐
2847              vice provider.
2848
2849       IXOLoginTimeout
2850              (IXO/TAP only) The maximum time, in seconds, to wait to complete
2851              the login procedure.
2852
2853       IXOGATimeout
2854              (IXO/TAP only) The maximum time, in seconds, to wait for  a  Go-
2855              Ahead message from the service provider.
2856
2857       IXOXmitRetries
2858              The  maximum number of times to try sending a text message block
2859              in a single call.
2860
2861       IXOXmitTimeout
2862              The maximum time, in seconds, to try transmitting a text message
2863              block.
2864
2865       IXOAckTimeout
2866              (IXO/TAP only) integer          30                      IXO: max
2867              time to wait for msg block ack (secs) The maximum time, in  sec‐
2868              onds, to wait for an acknowledgement to a transmitted message.
2869

PROTOTYPE CONFIGURATION FILES

2871       Per-modem  configuration  files  are  typically  derived from prototype
2872       files that have been created for known modems.  These  prototype  files
2873       are kept in the config subdirectory and, by convention, have names that
2874       identify a brand or type of modem and the DTE-DCE flow  control  scheme
2875       the  prototype  files  configures.  The faxaddmodem(8C) program that is
2876       used to configure a modem for use with HylaFAX selects a prototype con‐
2877       figuration file using information retrieved from the modem and comments
2878       embedded in the prototype files.  For Class 1  modems  the  product  ID
2879       code returned by the command ``ATI0'' and the response from the command
2880       ``ATI3'' are used to select a prototype configuration file,  while  for
2881       Class  2  modems the manufacturer and model as returned by ``AT+FMFR?''
2882       and  ``AT+FMDL?'',  respectively,  are   used   (or   ``AT+FMI?''   and
2883       ``AT+FMM?'' for Class 2.0 modems).
2884
2885       A  Class 1 prototype configuration file is identified for use by faxad‐
2886       dmodem by searching for a comment of the form:
2887       # CONFIG:CLASS1:144:.*:RTSCTS: Manufacturer='AT&T' Model=Dataport
2888       In this example ``144'' is the product ID code for an AT&T DataPort mo‐
2889       dem,  ``.*''  is a regular expression matched against the result string
2890       returned by the ``ATI3'' command, and ``RTSCTS'' indicates the modem is
2891       configured  to use hardware flow control during fax operation.  The re‐
2892       mainder of the line is evaluated by the sh(1) and used to  specify  the
2893       modem's  manufacturer and model (since Class 1 modems do not have stan‐
2894       dard commands to query this information).
2895
2896       Class 2 and 2.0 prototype configuration files match the string  ``manu‐
2897       facturer-model-flowcontrol''  against a sh(1) glob pattern specified in
2898       the configuration file, where manufacturer and model  are  the  strings
2899       returned by querying the modem and flowcontrol is either ``RTSCTS'' for
2900       hardware flow control or ``XONXOFF'' for software  flow  control.   For
2901       example:
2902       # CONFIG: CLASS2: ZyXEL*-RTSCTS
2903       # CONFIG: CLASS2.0: USRobotics*-XONXOFF
2904       are  configuration  comments  that  appear  in the prototype file for a
2905       ZyXEL 1496E with Class 2 support, and for a US Robotics  Courier  modem
2906       with Class 2.0 firmware.
2907
2908       The faxaddmodem program merges server-specific configuration parameters
2909       into a prototype configuration according to comments placed in the pro‐
2910       totype  file.   All  lines  between ``BEGIN-SERVER'' and ``END-SERVER''
2911       comments are placed with the appropriate server  configuration  parame‐
2912       ters.  Note that this means modem-related configuration parameters must
2913       be placed outside this area of the file.
2914

SEE ALSO

2916       faxaddmodem(8C),   faxq(8C),   faxgetty(8C),   faxsend(8C),    hylafax-
2917       server(5F)
2918
2919
2920
2921             $Date: 2013-02-26 15:46:36 -0800 (Tue, 26 Feb 20H1Y3L)AF$AX-CONFIG(5F)
Impressum