annotate xml/sample.conf @ 94:e107ade3b1c0

fix dos line terminators
author carl
date Wed, 21 Sep 2005 12:35:29 -0700
parents 591edabaf196
children 53a2fbe3f761
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
94
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
1 # $Id$
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
2 #
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
3
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
4 # Partial bnf description of this configuration language. Any sequence of
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
5 # three tokens ("include" FILENAME ";") are replaced by the content of the
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
6 # specified file.
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
7 #
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
8 #
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
9 # CONFIG = {CONTEXT ";"}+
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
10 # CONTEXT = "context" NAME "{" {STATEMENT}+ "}"
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
11 # STATEMENT = (DNSBL | DNSBLLIST | CONTENT | ENV-TO | CONTEXT | ENV-FROM) ";"
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
12
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
13 # DNSBL = "dnsbl" NAME DNSPREFIX ERROR-MSG
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
14
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
15 # DNSBLLIST = "dnsbl_list" {NAME}+
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
16
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
17 # CONTENT = "content" ("on" | "off") "{" {CONTENT-STATEMENT}+ "}"
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
18 # CONTENT-STATEMENT = (FILTER | IGNORE | TLD | HTML-TAGS | HTML-LIMIT | HOST-LIMIT) ";"
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
19 # FILTER = "filter" DNSPREFIX ERROR-MSG
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
20 # IGNORE = "ignore" "{" {HOSTNAME [";"]}+ "}"
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
21 # TLD = "tld" "{" {TLD [";"]}+ "}"
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
22 # HTML-TAGS = "html_tags" "{" {HTMLTAG [";"]}+ "}"
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
23 # ERROR-MSG = string containing exactly two %s replacement tokens for the client ip address
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
24
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
25 # HTML-LIMIT = "html_limit" ("on" INTEGER ERROR-MSG | "off")
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
26
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
27 # HOST-LIMIT = "host_limit" ("on" INTEGER ERROR-MSG | "off" | "soft" INTEGER)
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
28
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
29 # ENV-TO = "env_to" "{" {(TO-ADDR | DCC-TO)}+ "}"
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
30 # TO-ADDR = ADDRESS [";"]
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
31 # DCC-TO = "dcc_to" ("ok" | "many") "{" DCCINCLUDEFILE "}" ";"
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
32
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
33 # ENV_FROM = "env_from" [DEFAULT] "{" {(FROM-ADDR | DCC-FROM)}+ "}"
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
34 # FROM-ADDR = ADDRESS VALUE [";"]
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
35 # DCC-FROM = "dcc_from" "{" DCCINCLUDEFILE "}" ";"
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
36 # DEFAULT = ("white" | "black" | "unknown" | "inherit" | "")
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
37 # ADDRESS = (USER@ | DOMAIN | USER@DOMAIN)
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
38 # VALUE = ("white" | "black" | "unknown" | CHILD-CONTEXT-NAME)
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
39
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
40
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
41 context sample {
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
42 dnsbl local blackholes.five-ten-sg.com "Mail from %s rejected - local; see http://www.five-ten-sg.com/blackhole.php?%s";
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
43 dnsbl sbl sbl-xbl.spamhaus.org "Mail from %s rejected - sbl; see http://www.spamhaus.org/query/bl?ip=%s";
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
44 dnsbl xbl xbl.spamhaus.org "Mail from %s rejected - xbl; see http://www.spamhaus.org/query/bl?ip=%s";
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
45 dnsbl dul dul.dnsbl.sorbs.net "Mail from %s rejected - dul; see http://www.sorbs.net/lookup.shtml?%s";
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
46 dnsbl_list local sbl dul;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
47
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
48 content on {
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
49 filter sbl-xbl.spamhaus.org "Mail containing %s rejected - sbl; see http://www.spamhaus.org/query/bl?ip=%s";
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
50 ignore { include "hosts-ignore.conf"; };
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
51 tld { include "tld.conf"; };
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
52 html_tags { include "html-tags.conf"; };
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
53 html_limit on 20 "Mail containing excessive bad html tags rejected";
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
54 html_limit off;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
55 host_limit on 20 "Mail containing excessive host names rejected";
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
56 host_limit soft 20;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
57 };
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
58
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
59 env_to {
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
60 mydomain.com; # child contexts are not allowed to specify recipient addresses outside these domains
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
61 customer1.com;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
62 customer1a.com;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
63 customer1b.com;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
64 customer2.com;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
65 customer2a.com;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
66 customer2b.com;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
67 };
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
68
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
69 context whitelist {
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
70 content off {};
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
71 env_to {
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
72 # dcc_to ok { include "/var/dcc/whitecommon"; }; # copy the dcc OK values (env_to) into this context
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
73 };
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
74 env_from white {}; # white forces all unmatched from addresses (everyone in this case) to be whitelisted
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
75 # so all mail TO these env_to addresses is accepted
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
76 };
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
77
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
78 context abuse {
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
79 dnsbl_list xbl;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
80 content off {};
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
81 env_to {
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
82 abuse@; # no content filtering on abuse reports
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
83 postmaster@; # ""
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
84 };
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
85 env_from unknown {}; # ignore all parent white/black listing
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
86 };
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
87
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
88 context minimal {
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
89 dnsbl_list sbl dul;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
90 content on {};
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
91 env_to {
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
92 sales@mydomain.com;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
93 };
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
94 };
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
95
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
96 context blacklist {
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
97 env_to {
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
98 dcc_to many { include "/var/dcc/whitecommon"; }; # copy the dcc MANY values (env_to) into this context
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
99 old-employee@mydomain.com;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
100 };
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
101 env_from black {}; # black forces all unmatched from addresses (everyone in this case) to be blacklisted
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
102 # so all mail TO these env_to addresses is rejected
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
103 };
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
104
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
105 context vp { # special context for the vp
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
106 env_to {
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
107 vp@mydomain.com;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
108 };
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
109 env_from inherit {
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
110 nai.com black; # the vp does not like nai
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
111 yahoo.com unknown; # override parent context blacklisting
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
112 mother@spammyisp.com white; # suppress dnsbl checking
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
113 };
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
114 };
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
115
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
116 context customer1 {
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
117 dnsbl_list sbl dul;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
118 env_to {
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
119 customer1.com;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
120 customer1a.com;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
121 customer1b.com;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
122 };
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
123
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
124 verify mail.customer1.com;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
125
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
126 context customer1a {
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
127 env_to {
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
128 customer1a.com;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
129 }
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
130 env_from black { # blacklist everything
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
131 first@acceptable.com unknown; # except these specific envelope senders
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
132 second@another.com unknown;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
133 yahoo.com inherit; # delegate to the parent
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
134 };
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
135 };
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
136
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
137 env_from { # default value of the default is inherit
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
138 yahoo.com black; # no mail from yahoo
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
139 first@yahoo.com unknown; # except this one
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
140 };
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
141 };
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
142
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
143 context customer2 {
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
144 dnsbl_list sbl;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
145 env_to {
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
146 customer2.com;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
147 customer2a.com;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
148 customer2b.com;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
149 };
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
150 };
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
151
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
152 env_from unknown {
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
153 dcc_from { include "/var/dcc/whitecommon"; }; # copy the dcc OK/MANY values (env_from, substitute mail_host) into this context
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
154 abuse@ abuse; # replies to abuse reports use the abuse context
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
155 yahoo.com black; # don't take mail from yahoo
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
156 spammer@example.com black;
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
157 };
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
158 };
e107ade3b1c0 fix dos line terminators
carl
parents: 93
diff changeset
159