This file is indexed.

/etc/courier/faxrc is in courier-faxmail 0.78.0-2ubuntu2.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
##VERSION: $Id: 7b218a8185f424046f3ef3322a37443983e443e3-20150228120637$
#
# faxrc created from faxrc.dist by sysconftool
#
# Do not alter lines that begin with ##, they are used when upgrading
# this configuration.
#
#  Copyright 2002 Double Precision, Inc.  See COPYING for
#  distribution information.
#
##NAME: faxrc:0
#
# courierfax configuration directives.  These directives specify which
# phone numbers courierfax will dial, as well as some basic transformation
# rules.  The default set of directives are designed for the North American
# Number Plan dialing: seven digit local number, 1+10 digit area code.
#
# This should really be done by a Perl script, for maximum flexibility,
# however loading the Perl interpreter into the mail server code is just too
# much, so we're left with what we have.
#
# Blank lines in this file are ignored.  Lines that begin with # are comments,
# and are also ignored.  Because this file is processed by sysconftool,
# do not add comments in the middle or at the tail end of the configuration
# directives, otherwise you'll lose them on upgrades.  All the comments go
# here.
#
# There are two basic directives:
#
#   rw[flags]      [search]   [replace]
#
#   accept[flags]  [search]   [source]
#
#   reject[flags]  [search]   [source]
#
#  "Pattern" is described below.  The 'rw' directive rewrites the phone number.
#  If the phone number matches the "search" pattern, it is replaced with
#  "replace", and we continue to the next directive.  If the phone number
#  doesn't match 'search', we go on to the next directive.
#
#  The 'accept' directive "accepts" the phone number.  If the phone number
#  matches the "search" pattern, and the mail originates from "source", the
#  phone number is accepted.  "source" must be one of the following strings:
#  local, esmtp, uucp, dsn.  This allows, for example, to send faxes only
#  from locally-originated mail, and not for mail received via ESMTP.
#
#  The 'reject' directive is the opposite of 'accept'.  If the phone number
#  matches the "search" pattern, and the mail originates from "source", the
#  phone number is immediately rejected, without further processing.
#
#  Note that after the 'accept' directive is processed, courierfax continues
#  to process the rest of the file.  When the entire faxrc file is read,
#  courierfax determines if the phone number was accepted, if not the message
#  is bounced.
#
#  Therefore, the overall strategy is as follows:
#
#  1) Issue 'rw' directives that rewrite the phone number into a 'canonical'
#     form.  For NANPA, it's either a 10-digit phone number (without 1+), or
#     011 followed by an international phone number.
#
#  2) Issue accept directives.  Here, it's still possible to discriminate,
#     in the sample case, between international and local phone numbers.
#
#  3) Issue 'rw' directives that post-process the phone number, for example:
#     drop the default area code, prepend any dialing prefixes, such as "9,".
#
#  The 'rw' and 'accept' directives may be followed by the following
#  characters:
#
#  ^    It is sufficient for the pattern to match the phone number's prefix
#       only.  Normally, the pattern must match the entire phone number.
#
#  *    If the pattern matches, lather, rinse, and repeat.  Only meaningful for
#       the 'rw' directive.
#
#  SEARCH
#
#  The "search" string is compared against the phone number, verbatim, except
#  for the following character sequences:
#
#  n      The 'n' character in the search pattern matches any digit in the
#         phone number (there are other things in the phone number, you know,
#         such as *, #, and commas).
#
#  .      The '.' character in the search pattern will match any single
#         character in the phone number.
#
#  ( .. ) Stuff inside the parenthesis is compared against the phone number,
#         and if it matches, it is made available in the replacement string
#         as "$1".  The second occurence of () is made available in the
#         replacement string as "$2".  Up to eight parenthesis pairs may be
#         specified and they may not nest.
#
#  ~      Matches the DTMF '#' character in the phone number.  Because the
#         DTMF character '#' conflicts with the comment character in this
#         configuration file, the ~ character represents the DTMF # character
#         in this configuration file.
#
#  -      Matches the , character in the dialing string.  Since commas are used
#         in E-mail headers to separate addresses, a dash in the local part
#         of the E-mail address is translated to a comma in the dialing string.
#
#  +      Matches the @ character in the dialing string.  Since @s are used
#         in E-mail addresses for other purposes, a + in the local part of
#         the E-mail address is replaced with the @ character in the dialing
#         string.
#
#  Anything else in the search pattern must match the phone number string
#  verbatim.
#
#  REPLACE
#
#  If the SEARCH string matches the phone number, it is replaced by the
#  REPLACE string, and the next line in this configuration file is read.
#  $1, $2 ... $8 in REPLACE is replaced by the corresponding parts of the
#  original phone number, as designated by the ( .. ) pairs.  When the
#  'rw' keyword is followed by '^', trailing parts of the original phone
#  number are available as $9.
#
#
#  EXPLANATION OF DEFAULT REWRITING RULES.
#
#  Here's the explanation the default set of configuration directives
#  from the Courier distribution.  The default set of configuration directives
#  is for the North American dialing plan, with a nonexistent local area code
#  of "999", that uses seven digit local dialing.
#
#  Step 1: Convert all phone numbers to canonical form: a ten digit
#  areacode+phone number, or a variable length international phone number that
#  begins with 1:
#
#  rw^*    1               $9
#
#        -- first things first: remove all leading 1s from the phone #
#
#  rw^     011             1011$9
#  rw^     n11             1
#  rw^     1011            011$9
#
#        -- now, what this is all about is that we want to reject all
#           phone numbers that begin with x11 (such as 911, you don't want
#           to send any faxes there, of course),  EXCEPT for the international
#           011 prefix.  Therefore, we first prepend a "1" to all 011 numbers
#           then replace ANY number that begins with x11 with a single
#           digit 1 (that's the entire phone number, which gets later rejected
#           as an invalid).  Finally, we lop replace 1011 with 011.
#
#  rw      (nnnnnnn)       999$1
#
#        -- Prefix the default area code of "999" to all seven digit numbers.
#
# Step 2: Accept all valid numbers to dial
#
# accept   2nnnnnnnnn   local
# accept   2nnnnnnnnn   esmtp
#
# ...
#
# accept   9nnnnnnnnn   local
# accept   9nnnnnnnnn   esmtp
#
#  So, we now accept all 10 digit numbers that begin with 2 through 9 as
#  valid.  "accept [whatever] local" accepts this number from local senders,
#  and "accept [whatever] esmtp" accepts this number from remote (esmtp)
#  senders.
#
#  Do not specify the 'dsn' module, unless you have no problems with some
#  joker causing your server to fax-bomb someone with bounces.
#
#  Now, listing "esmtp" does not automatically allow anyone in the world to
#  send faxes.  You still need to set FAXRELAYCLIENT, as described in the
#  following note:
#
#  NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE
#
#   Some mail clients, like Pine, send mail via ESMTP to localhost (usually
#   by running 'sendmail -bs').  That looks like esmtp mail to courierfax,
#   therefore the default configuration, below, also accepts esmtp.  HOWEVER:
#   faxes are accepted via ESMTP only after an additional requirement of the
#   FAXRELAYCLIENT envuironment variable being set, which is typically
#   implemented by setting FAXRELAYCLIENT for authorized IP address ranges
#   only (and FAXRELAYCLIENT is automatically set by sendmail -bs, and by
#   authenticated via ESMTP).
#
#  NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE
#
#
# accept^ 011    local
# accept^ 011    esmtp
#
#       -- This allows faxes to be sent to international phone numbers.
#          Remove these two lines to block faxes to international numbers.
#
# Step 3 - we're almost there.  Time to specify how numbers should be dialed.
#
# rw^    (.)       1$1$9
# rw^    1011      011$9
# rw^    1999      $9
#
#       -- First, we prepend 1 to every number, then remove it for
#          international calls.  So now we have two possibilities:
#          a) 011+international number, and b) 1+10 digit area code.
#
#          Finally, we want all numbers in the 999 area code to be dialed
#          as ten digits.  Numbers in the 999 area code are currently
#          prefixed with "1999", so we drop that.
#
#  OPTIONAL EXTRA:
#
#  rw^   (.)       9,$1$9
#
#       -- This prepends "9," to every phone number dialed.  Append this
#          extra rule at the very end, to take effect for any number.
#
#  ALTERNATIVE #1: ten digit local calling.
#  Some areas in North America dial ten digit for local calls (in a small
#  number of area codes), and 1+ten digits for all other area codes.
#  Say that our local calling area includes the 999 and 998 area codes,
#  which must be dialed 10 digits, with 1+10 digits for everyone else.
#  Here's the third portion of the rewriting rules that accomplishes that:
#
#  rw^    (.)       1$1$9
#  rw^    1011      011$9
#  rw^    1999      999$9
#  rw^    1998      998$9
#
#  Think - you should be able to figure out how this works, by now.
#
#  IMPORTANT IMPORTANT IMPORTANT IMPORTANT
#
#  Remove the first 'rw' line below - "rw^   .    1" - this is a hack to
#  disable fax transmission in the default Courier install, so that it has
#  to be manually enabled.  After removing the first 'rw' line, everything
#  above this paragraph becomes applicable!
#

rw^     .               1

rw^*    1               $9
rw^     011             1011$9
rw^     n11             1
rw^     1011            011$9
rw      (nnnnnnn)       999$1
accept   2nnnnnnnnn   local
accept   2nnnnnnnnn   esmtp
accept   3nnnnnnnnn   local
accept   3nnnnnnnnn   esmtp
accept   4nnnnnnnnn   local
accept   4nnnnnnnnn   esmtp
accept   5nnnnnnnnn   local
accept   5nnnnnnnnn   esmtp
accept   6nnnnnnnnn   local
accept   6nnnnnnnnn   esmtp
accept   7nnnnnnnnn   local
accept   7nnnnnnnnn   esmtp
accept   8nnnnnnnnn   local
accept   8nnnnnnnnn   esmtp
accept   9nnnnnnnnn   local
accept   9nnnnnnnnn   esmtp
accept^ 011    local
accept^ 011    esmtp
rw^    (.)       1$1$9
rw^    1011      011$9
rw^    1999      $9