73
|
1 #ifndef context_include
|
|
2 #define context_include
|
|
3
|
71
|
4 #include "tokenizer.h"
|
|
5 #include <map>
|
|
6
|
|
7
|
|
8 enum status {oksofar, // not rejected yet
|
|
9 white, // whitelisted
|
|
10 black, // blacklisted
|
75
|
11 reject}; // rejected by a dns list
|
71
|
12
|
|
13 class DNSBL;
|
|
14 class CONTEXT;
|
73
|
15 class recorder;
|
71
|
16
|
|
17 typedef map<char *, char *, ltstr> string_map;
|
|
18 typedef set<int> int_set;
|
|
19 typedef list<char *> string_list;
|
|
20 typedef DNSBL * DNSBLP;
|
|
21 typedef list<DNSBLP> dnsblp_list;
|
|
22 typedef map<char *, DNSBLP, ltstr> dnsblp_map;
|
|
23 typedef CONTEXT * CONTEXTP;
|
|
24 typedef list<CONTEXTP> context_list;
|
|
25 typedef map<char *, CONTEXTP, ltstr> context_map;
|
|
26 typedef map<char *, int, ltstr> ns_mapper;
|
|
27
|
|
28 struct DNSBL {
|
|
29 char *name; // nickname for this dns based list
|
|
30 char *suffix; // blacklist suffix like blackholes.five-ten-sg.com
|
|
31 char *message; // error message with one or two %s operators for the ip address replacement
|
|
32 DNSBL(char *n, char *s, char *m);
|
|
33 };
|
|
34
|
|
35 class CONTEXT {
|
|
36 CONTEXTP parent;
|
|
37 char * name;
|
|
38 context_map children; // map child context names to their contexts
|
|
39 string_set env_to; //
|
|
40 string_map env_from; // map senders to white/black/unknown
|
|
41 context_map env_from_context; // map senders to a child context
|
|
42 char * env_from_default; // default value for senders that are not found in the map white/black/unknown/inherit
|
|
43 bool content_filtering; //
|
|
44 char * content_suffix; // for sbl url body filtering
|
|
45 char * content_message; // ""
|
|
46 string_set content_host_ignore;// hosts to ignore for content sbl checking
|
|
47 string_set content_tlds; //
|
|
48 string_set html_tags; // set of valid html tags
|
|
49 int host_limit; // limit on host names
|
|
50 char * host_limit_message; // error message for excessive host names
|
|
51 bool host_random; // pick a random selection of host names rather than error for excessive hosts
|
|
52 int tag_limit; // limit on bad html tags
|
|
53 char * tag_limit_message; // error message for excessive bad html tags
|
|
54 dnsblp_map dnsbl_names; // name to dnsbl mapping for lists that are available in this context and children
|
|
55 dnsblp_list dnsbl_list; // list of dnsbls to be used in this context
|
|
56
|
|
57 public:
|
|
58 CONTEXT(CONTEXTP parent_, char *name_);
|
|
59 ~CONTEXT();
|
|
60 CONTEXTP get_parent() {return parent;};
|
76
|
61 bool is_parent(CONTEXTP p); // is p a parent of this?
|
71
|
62 char* get_full_name(char *buf, int size);
|
|
63 void add_context(CONTEXTP child) {children[child->name] = child;};
|
|
64 bool allow_env_to(char *to) {return (parent) ? parent->cover_env_to(to) : true;};
|
|
65 bool cover_env_to(char *to);
|
|
66
|
|
67 void add_to(char *to) {env_to.insert(to);};
|
|
68 void add_from(char *from, char *status) {env_from[from] = status;};
|
|
69 void add_from_context(char *from, CONTEXTP con) {env_from_context[from] = con;};
|
|
70 void set_from_default(char *status) {env_from_default = status;};
|
|
71 char* find_from(char *from);
|
75
|
72 CONTEXTP find_context(char *from);
|
71
|
73 CONTEXTP find_from_context_name(char *name);
|
|
74
|
|
75 void set_content_filtering(bool filter) {content_filtering = filter;};
|
|
76 void set_content_suffix(char *suffix) {content_suffix = suffix;};
|
|
77 void set_content_message(char *message) {content_message = message;};
|
|
78 void add_ignore(char *host) {content_host_ignore.insert(host);};
|
|
79 void add_tld(char *tld) {content_tlds.insert(tld);};
|
|
80
|
|
81 void set_host_limit(int limit) {host_limit = limit;};
|
|
82 void set_host_message(char *message) {host_limit_message = message;};
|
|
83 void set_host_random(bool random) {host_random = random;};
|
|
84 void set_tag_limit(int limit) {tag_limit = limit;};
|
|
85 void set_tag_message(char *message) {tag_limit_message = message;};
|
|
86 void add_tag(char *tag) {html_tags.insert(tag);};
|
|
87
|
|
88 void add_dnsbl(char *name, DNSBLP dns) {dnsbl_names[name] = dns;};
|
|
89 void add_dnsbl(DNSBLP dns) {dnsbl_list.push_back(dns);};
|
|
90 DNSBLP find_dnsbl(char *name);
|
|
91
|
76
|
92 bool get_content_filtering() {return content_filtering;};
|
73
|
93 int get_host_limit() {return host_limit;};
|
|
94 bool get_host_random() {return host_random;};
|
76
|
95 char* get_content_suffix();
|
|
96 char* get_content_message();
|
|
97 string_set& get_content_host_ignore();
|
|
98 string_set& get_content_tlds();
|
|
99 string_set& get_html_tags();
|
|
100 dnsblp_list& get_dnsbl_list();
|
73
|
101
|
74
|
102 bool acceptable_content(recorder &memory, char *&msg);
|
73
|
103 bool ignore_host(char *host);
|
|
104
|
71
|
105 void dump(int level = 0);
|
|
106 };
|
|
107
|
|
108
|
|
109 struct CONFIG {
|
|
110 // the only mutable stuff once it has been loaded from the config file
|
|
111 int reference_count; // protected by the global config_mutex
|
|
112 // all the rest is constant after loading from the config file
|
|
113 int generation;
|
|
114 time_t load_time;
|
|
115 string_set config_files;
|
|
116 context_list contexts; // owns all the contexts, not just top level contexts
|
|
117 context_map env_to; // map recipient to a filtering context
|
|
118 CONTEXTP default_context;// for env_to values that don't have their own specific filtering context
|
73
|
119 // the default context is also used for some of the content filtering values
|
71
|
120
|
|
121 CONFIG();
|
|
122 ~CONFIG();
|
|
123 void add_context(CONTEXTP con);
|
75
|
124 void add_to(char *to, CONTEXTP con);
|
|
125 CONTEXTP find_context(char *to);
|
71
|
126 void dump();
|
|
127 };
|
|
128
|
|
129 extern char *token_black;
|
|
130 extern char *token_content;
|
|
131 extern char *token_context;
|
|
132 extern char *token_dccfrom;
|
|
133 extern char *token_dccto;
|
|
134 extern char *token_default;
|
|
135 extern char *token_dnsbl;
|
|
136 extern char *token_dnsbll;
|
|
137 extern char *token_envfrom;
|
|
138 extern char *token_envto;
|
|
139 extern char *token_filter;
|
|
140 extern char *token_host_limit;
|
|
141 extern char *token_html_limit;
|
|
142 extern char *token_html_tags;
|
|
143 extern char *token_ignore;
|
|
144 extern char *token_include;
|
|
145 extern char *token_inherit;
|
|
146 extern char *token_lbrace;
|
75
|
147 extern char *token_mailhost;
|
71
|
148 extern char *token_many;
|
|
149 extern char *token_off;
|
|
150 extern char *token_ok;
|
|
151 extern char *token_ok2;
|
|
152 extern char *token_on;
|
|
153 extern char *token_rbrace;
|
|
154 extern char *token_semi;
|
|
155 extern char *token_soft;
|
75
|
156 extern char *token_substitute;
|
71
|
157 extern char *token_tld;
|
|
158 extern char *token_unknown;
|
|
159 extern char *token_white;
|
|
160
|
|
161 extern string_set all_strings; // owns all the strings, only modified by the config loader thread
|
|
162
|
74
|
163 void discard(string_set &s);
|
71
|
164 char* register_string(string_set &s, char *name);
|
|
165 char* register_string(char *name);
|
|
166 CONFIG *parse_config(char *fn);
|
|
167 bool load_conf(CONFIG &dc, char *fn);
|
|
168 void token_init();
|
73
|
169
|
|
170 #endif
|