masqmail
changeset 317:55b7bde95d37
reworked allowed and denied addrs for routes
The following refactorings had been made:
- allowed_mail_locals + allowed_return_paths -> allowed_senders
- not_allowed_mail_locals + not_allowed_return_paths -> denied_senders
- allowed_rcpt_domains -> allowed_recipients
- not_allowed_rcpt_domains -> denied_recipients
The new options allow more consistent and more flexible matching.
author | meillo@marmaro.de |
---|---|
date | Thu, 28 Apr 2011 09:55:06 +0200 (2011-04-28) |
parents | d596ac8b5afb |
children | 290da1595311 |
files | admin/config-transition examples/example.route examples/openssl.route man/masqmail.route.5 src/address.c src/conf.c src/deliver.c src/masqmail.h src/route.c |
diffstat | 9 files changed, 167 insertions(+), 140 deletions(-) [+] |
line diff
1.1 --- a/admin/config-transition Mon Apr 25 15:17:30 2011 +0200 1.2 +++ b/admin/config-transition Thu Apr 28 09:55:06 2011 +0200 1.3 @@ -67,7 +67,7 @@ 1.4 " 1.5 1.6 check["online_detect"] = "conf" SUBSEP "Removed in 0.3.2" SUBSEP "\ 1.7 -Destilled to online_query. \ 1.8 +Distilled to online_query. \ 1.9 " 1.10 1.11 check["online_file"] = "conf" SUBSEP "Removed in 0.3.2" SUBSEP "\ 1.12 @@ -96,6 +96,34 @@ 1.13 If pipe is given, pipe will be used, otherwise smtp will be used. \ 1.14 " 1.15 1.16 +check["(^|[ ])allowed_return_paths"] = "route" SUBSEP "Removed in 0.3.2" SUBSEP "\ 1.17 +Replaced by 'allowed_senders'. \ 1.18 +" 1.19 + 1.20 +check["not_allowed_return_paths"] = "route" SUBSEP "Removed in 0.3.2" SUBSEP "\ 1.21 +Replaced by 'denied_senders'. \ 1.22 +" 1.23 + 1.24 +check["(^|[ ])allowed_mail_locals"] = "route" SUBSEP "Removed in 0.3.2" SUBSEP "\ 1.25 +Replaced by 'allowed_senders', if neither wildcards nor '@' is used. \ 1.26 +" 1.27 + 1.28 +check["not_allowed_mail_locals"] = "route" SUBSEP "Removed in 0.3.2" SUBSEP "\ 1.29 +Replaced by 'denied_senders', if neither wildcards nor '@' is used. \ 1.30 +" 1.31 + 1.32 +check["(^|[ ])allowed_rcpt_domains"] = "route" SUBSEP "Removed in 0.3.2" SUBSEP "\ 1.33 +Replaced by 'allowed_recipients', if the values are prepended with \ 1.34 +'*@', because 'allowed_recipients' matches complete addresses not just \ 1.35 +domains. \ 1.36 +" 1.37 + 1.38 +check["not_allowed_rcpt_domains"] = "route" SUBSEP "Removed in 0.3.2" SUBSEP "\ 1.39 +Replaced by 'denied_recipients', if the values are prepended with \ 1.40 +'*@', because 'allowed_recipients' matches complete addresses not just \ 1.41 +domains. \ 1.42 +" 1.43 + 1.44 # get files 1.45 1.46 # already covered by the get.* and online_gets.* options in the conf
2.1 --- a/examples/example.route Mon Apr 25 15:17:30 2011 +0200 2.2 +++ b/examples/example.route Thu Apr 28 09:55:06 2011 +0200 2.3 @@ -6,10 +6,10 @@ 2.4 # 2.5 2.6 # users that can send mail over this connection: 2.7 -# this is a list of the local parts of the original return addresses, as they are 2.8 +# this is a list of the envelope sender addresses, as they are 2.9 # configured with your mail client. If not set, anybody may send. 2.10 2.11 -allowed_mail_locals = "okurth" 2.12 +allowed_senders = "okurth" 2.13 2.14 # local_hosts and local_nets will be checked before this. 2.15 # cpwright.com uses the dialup up list of dul.maps.vix.com, 2.16 @@ -20,7 +20,7 @@ 2.17 # You will find this necessary only if you send mail directly 2.18 # (if mail_host is not set below) 2.19 2.20 -not_allowed_rcpt_domains = "cpwright.com" 2.21 +denied_recipients = "*@cpwright.com" 2.22 2.23 # 2.24 # settings:
3.1 --- a/examples/openssl.route Mon Apr 25 15:17:30 2011 +0200 3.2 +++ b/examples/openssl.route Thu Apr 28 09:55:06 2011 +0200 3.3 @@ -14,8 +14,8 @@ 3.4 #wrapper="/usr/bin/openssl s_client -quiet -connect mail.gmx.net:465 2>/dev/null" 3.5 3.6 3.7 -# which addresses are allowed through this route? 3.8 -allowed_return_paths = "*@gmx.de;*@gmx.net" 3.9 +# which sender addresses are allowed for this route? 3.10 +allowed_senders = "*@gmx.de;*@gmx.net" 3.11 3.12 # the authentication method 3.13 #auth_name = "cram-md5"
4.1 --- a/man/masqmail.route.5 Mon Apr 25 15:17:30 2011 +0200 4.2 +++ b/man/masqmail.route.5 Thu Apr 28 09:55:06 2011 +0200 4.3 @@ -17,62 +17,65 @@ 4.4 .SH ROUTE CONDITIONS 4.5 4.6 .TP 4.7 -\fBallowed_mail_locals\fR = \fIlist\fR 4.8 +\fBallowed_senders\fR = \fIlist\fR 4.9 4.10 -This is a semicolon `;' separated list of local parts of envelope 4.11 -senders (= mail from = return path) which will be allowed 4.12 -to send mail through this connection. 4.13 -If unset and \fBnot_allowed_mail_locals\fR is also unset, all users are allowed. 4.14 +This is a semicolon `;' separated list of envelope sender addresses. 4.15 +Messages which have one of these addresses as the return path (= mail 4.16 +from) are allowed to use this route 4.17 +(if not also in \fBdenied_senders\fR). 4.18 + 4.19 +Glob patterns containing `?' and `*' can be used. 4.20 +The special item "<>" matches the null sender address 4.21 +(eg. failure notices or delivery notifications). 4.22 +If the pattern doesn't contain an `@', it is seen as a pattern for the 4.23 +local part only. 4.24 + 4.25 +Example: \fImeillo;*@*example.org;web*@example.com\fP 4.26 + 4.27 +(``meillo'' equals ``meillo@*'', i.e. the local part.) 4.28 4.29 .TP 4.30 -\fBnot_allowed_mail_locals\fR = \fIlist\fR 4.31 +\fBdenied_senders\fR = \fIlist\fR 4.32 4.33 -This is a semicolon `;' separated list of local parts of envelope 4.34 -senders (= mail from = return path) which will be not allowed 4.35 -to send mail through this connection. 4.36 -Local parts in this list will not be allowed to use this route even if they 4.37 -are part of \fBallowed_mail_locals\fR (see above). 4.38 +This is a semicolon `;' separated list of envelope sender addresses. 4.39 +Messages which have one of these addresses as the return path (= 4.40 +mail from) will not 4.41 +be sent using this route (even if also in \fBallowed_senders\fR). 4.42 + 4.43 +Glob patterns containing `?' and `*' can be used. 4.44 +The special item "<>" matches the null sender address 4.45 +(eg. failure notices or delivery notifications). 4.46 +If the pattern doesn't contain an `@', it is seen as a pattern for the 4.47 +local part only. 4.48 + 4.49 +Example: (see \fIallowed_senders\fP) 4.50 4.51 .TP 4.52 -\fBallowed_return_paths\fR = \fIlist\fR 4.53 +\fBallowed_recipients\fR = \fIlist\fR 4.54 4.55 -This is a semicolon `;' separated list of addresses. 4.56 -Messages which have one of these addresses as the return path (= 4.57 -envelope sender = mail from) will be used using this route 4.58 -(if not also in \fBnot_allowed_return_paths\fR or an item in \fBnot_allowed_mail_locals\fR matches). 4.59 +A list of envelope recipient addresses where mail can be sent to using 4.60 +this route. 4.61 +This is for example useful if you use this route configuration when connected to another LAN via ppp. 4.62 +Glob patterns containing `?' and `*' can be used. 4.63 4.64 -Patterns containing `?' and `*' can be used. 4.65 -The special item "<>" matches the null sender address (eg. failure notices or delivery notifications). 4.66 +Example: \fI*@example.org;*@*foo.bar\fP 4.67 + 4.68 +(See also examples for \fIallowed_senders\fP) 4.69 4.70 .TP 4.71 -\fBnot_allowed_return_paths\fR = \fIlist\fR 4.72 +\fBdenied_recipients\fR = \fIlist\fR 4.73 4.74 -This is a semicolon `;' separated list of addresses. 4.75 -Messages which have one of these addresses as the return path (= 4.76 -envelope sender = mail from) will not 4.77 -be used using this route (even if also in \fBallowed_return_paths\fR 4.78 -or an item in \fBallowed_mail_locals\fR matches). 4.79 - 4.80 -Patterns containing `?' and `*' can be used. 4.81 -The special item "<>" matches the null sender address (eg. failure notices or delivery notifications). 4.82 - 4.83 -.TP 4.84 -\fBallowed_rcpt_domains\fR = \fIlist\fR 4.85 - 4.86 -A list of recipient domains (of envelope recipients) where mail will be sent to. 4.87 -This is for example useful if you use this route configuration when connected to another LAN via ppp. 4.88 -Patterns containing `?' and `*' can be used. 4.89 - 4.90 -.TP 4.91 -\fBnot_allowed_rcpt_domains\fR = \fIlist\fR 4.92 - 4.93 -A list of recipient domains (of envelope recipients) where mail will not be sent to. 4.94 +A list of envelope recipient addresses where mail will not be sent to 4.95 +using this route. 4.96 This is for example useful if you send mail directly (\fBmail_host\fR is not set) 4.97 and you know of hosts that will not accept mail from you because they use a dialup list 4.98 (eg. \fBhttp://maps.vix.com/dul/\fR). 4.99 -If any domain matches both \fBallowed_rcpt_domains\fR and \fBnot_allowed_rcpt_domains\fR, 4.100 -mail will not be sent to this domain. 4.101 -Patterns containing `?' and `*' can be used. 4.102 +\fBdenied_recipients\fR overrules \fBallowed_recipients\fR. 4.103 +Glob patterns containing `?' and `*' can be used. 4.104 + 4.105 +Example: \fI*@spamblocker.example.org\fP 4.106 + 4.107 +(See also examples for \fIallowed_senders\fP) 4.108 4.109 .TP 4.110 \fBlast_route\fR = \fIboolean\fR 4.111 @@ -80,8 +83,9 @@ 4.112 If this is set, a mail which would have been delivered using this route, 4.113 but has failed temporarily, will not be tried to be delivered using the next route. 4.114 4.115 -If you have set up a special route with filters using the lists `allowed_rcpt_domains', 4.116 -`allowed_return_paths', and `allowed_mail_locals' or their complements (not_), 4.117 +If you have set up a special route with filters using the lists 4.118 +`allowed_recipients' and `allowed_senders' or their complements 4.119 +(denied_), 4.120 and the mail passing these rules should be delivered using this route only, 4.121 you should set this to `true'. 4.122 Otherwise the mail would be passed to the next route (if any),
5.1 --- a/src/address.c Mon Apr 25 15:17:30 2011 +0200 5.2 +++ b/src/address.c Thu Apr 28 09:55:06 2011 +0200 5.3 @@ -17,7 +17,6 @@ 5.4 */ 5.5 5.6 #include "masqmail.h" 5.7 -#include <fnmatch.h> 5.8 5.9 address* 5.10 create_address(gchar * path, gboolean is_rfc821) 5.11 @@ -186,15 +185,3 @@ 5.12 } 5.13 return buffer; 5.14 } 5.15 - 5.16 -gint 5.17 -addr_match(address * addr1, address * addr2) 5.18 -{ 5.19 - int res; 5.20 - 5.21 - if ((res = fnmatch(addr1->local_part, addr2->local_part, 0)) == 0) { 5.22 - if ((res = fnmatch(addr1->domain, addr2->domain, FNM_CASEFOLD)) == 0) 5.23 - return 0; 5.24 - } 5.25 - return res; 5.26 -}
6.1 --- a/src/conf.c Mon Apr 25 15:17:30 2011 +0200 6.2 +++ b/src/conf.c Thu Apr 28 09:55:06 2011 +0200 6.3 @@ -142,8 +142,14 @@ 6.4 return list; 6.5 } 6.6 6.7 +/* Split the addrs at '@' into local_part and domain. Without an '@' 6.8 + everything is local_part. Create address structs, which are put 6.9 + into a list and returned. 6.10 + This funktion is used for lists of addrs containing globbing chars (* and ?). 6.11 + We don't need valid RFC821 addresses here, just patterns to match against. 6.12 +*/ 6.13 static GList* 6.14 -parse_address_list(gchar * line, gboolean read_file) 6.15 +parse_address_glob_list(gchar * line, gboolean read_file) 6.16 { 6.17 GList *plain_list = parse_list(line, read_file); 6.18 GList *node; 6.19 @@ -151,13 +157,32 @@ 6.20 6.21 foreach(plain_list, node) { 6.22 gchar *item = (gchar *) (node->data); 6.23 - address *addr = create_address(item, TRUE); 6.24 - if (addr) 6.25 - list = g_list_append(list, addr); 6.26 + char* at; 6.27 + char* p; 6.28 + address *addr = calloc(1, sizeof(address)); 6.29 + 6.30 + for (p=item+strlen(item)-1; isspace(*p) || *p=='>'; p--) { 6.31 + *p = '\0'; 6.32 + } 6.33 + for (p=item; isspace(*p) || *p=='<'; p++) { 6.34 + } 6.35 + 6.36 + addr->address = strdup(p); 6.37 + at = strrchr(p, '@'); 6.38 + if (at) { 6.39 + *at = '\0'; 6.40 + addr->local_part = strdup(p); 6.41 + addr->domain = strdup(at+1); 6.42 + } else { 6.43 + addr->local_part = strdup(p); 6.44 + addr->domain = ""; 6.45 + } 6.46 + list = g_list_append(list, addr); 6.47 + DEBUG(6) debugf("parse_address_glob_list: read pattern `%s' `%s'\n", 6.48 + addr->local_part, addr->domain); 6.49 g_free(item); 6.50 } 6.51 g_list_free(plain_list); 6.52 - 6.53 return list; 6.54 } 6.55 6.56 @@ -648,18 +673,16 @@ 6.57 route->instant_helo = parse_boolean(rval); 6.58 else if (strcmp(lval, "do_pipelining") == 0) 6.59 route->do_pipelining = parse_boolean(rval); 6.60 - else if (strcmp(lval, "allowed_return_paths") == 0) 6.61 - route->allowed_return_paths = parse_address_list(rval, TRUE); 6.62 - else if (strcmp(lval, "allowed_mail_locals") == 0) 6.63 - route->allowed_mail_locals = parse_list(rval, TRUE); 6.64 - else if (strcmp(lval, "not_allowed_return_paths") == 0) 6.65 - route->not_allowed_return_paths = parse_address_list(rval, TRUE); 6.66 - else if (strcmp(lval, "not_allowed_mail_locals") == 0) 6.67 - route->not_allowed_mail_locals = parse_list(rval, TRUE); 6.68 - else if (strcmp(lval, "allowed_rcpt_domains") == 0) 6.69 - route->allowed_rcpt_domains = parse_list(rval, TRUE); 6.70 - else if (strcmp(lval, "not_allowed_rcpt_domains") == 0) 6.71 - route->not_allowed_rcpt_domains = parse_list(rval, TRUE); 6.72 + 6.73 + else if (strcmp(lval, "allowed_senders") == 0) 6.74 + route->allowed_senders = parse_address_glob_list(rval, TRUE); 6.75 + else if (strcmp(lval, "denied_senders") == 0) 6.76 + route->denied_senders = parse_address_glob_list(rval, TRUE); 6.77 + else if (strcmp(lval, "allowed_recipients") == 0) 6.78 + route->allowed_recipients = parse_address_glob_list(rval, TRUE); 6.79 + else if (strcmp(lval, "denied_recipients") == 0) 6.80 + route->denied_recipients = parse_address_glob_list(rval, TRUE); 6.81 + 6.82 else if (strcmp(lval, "set_h_from_domain") == 0) 6.83 route->set_h_from_domain = g_strdup(rval); 6.84 else if (strcmp(lval, "set_h_reply_to_domain") == 0) 6.85 @@ -808,10 +831,10 @@ 6.86 g_free(r->wrapper); 6.87 if (r->helo_name) 6.88 g_free(r->helo_name); 6.89 - _g_list_free_all(r->allowed_mail_locals); 6.90 - _g_list_free_all(r->not_allowed_mail_locals); 6.91 - _g_list_free_all(r->allowed_rcpt_domains); 6.92 - _g_list_free_all(r->not_allowed_rcpt_domains); 6.93 + _g_list_free_all(r->allowed_senders); 6.94 + _g_list_free_all(r->denied_senders); 6.95 + _g_list_free_all(r->allowed_recipients); 6.96 + _g_list_free_all(r->denied_recipients); 6.97 if (r->set_h_from_domain) 6.98 g_free(r->set_h_from_domain); 6.99 if (r->set_h_reply_to_domain)
7.1 --- a/src/deliver.c Mon Apr 25 15:17:30 2011 +0200 7.2 +++ b/src/deliver.c Thu Apr 28 09:55:06 2011 +0200 7.3 @@ -560,21 +560,21 @@ 7.4 continue; 7.5 } 7.6 7.7 - /* filter by allowed return paths (= envelope sender) */ 7.8 - if (!route_is_allowed_mail_local(route, msgout->msg->return_path) 7.9 - || !route_is_allowed_return_path(route, msgout->msg->return_path)) { 7.10 + /* filter by allowed envelope sender */ 7.11 + if (!route_sender_is_allowed(route, msgout->msg->return_path)) { 7.12 destroy_msg_out(msgout_cloned); 7.13 continue; 7.14 } 7.15 7.16 - /* filter by allowed rcpt addrs (= envelope rcpts) */ 7.17 - GList *rcpt_list_allowed = NULL, *rcpt_list_notallowed = NULL; 7.18 - msg_rcptlist_route(route, msgout_cloned->rcpt_list, &rcpt_list_allowed, &rcpt_list_notallowed); 7.19 - 7.20 + /* filter by allowed envelope rcpts */ 7.21 + GList* rcpt_list_allowed = NULL; 7.22 + GList* rcpt_list_notallowed = NULL; 7.23 + route_split_rcpts(route, msgout_cloned->rcpt_list, &rcpt_list_allowed, &rcpt_list_notallowed); 7.24 if (!rcpt_list_allowed) { 7.25 destroy_msg_out(msgout_cloned); 7.26 continue; 7.27 } 7.28 + 7.29 logwrite(LOG_NOTICE, "%s using '%s'\n", msgout->msg->uid, route->name); 7.30 7.31 g_list_free(msgout_cloned->rcpt_list);
8.1 --- a/src/masqmail.h Mon Apr 25 15:17:30 2011 +0200 8.2 +++ b/src/masqmail.h Thu Apr 28 09:55:06 2011 +0200 8.3 @@ -84,12 +84,10 @@ 8.4 gboolean is_local_net; 8.5 gboolean last_route; 8.6 8.7 - GList *allowed_return_paths; 8.8 - GList *not_allowed_return_paths; 8.9 - GList *allowed_mail_locals; 8.10 - GList *not_allowed_mail_locals; 8.11 - GList *allowed_rcpt_domains; 8.12 - GList *not_allowed_rcpt_domains; 8.13 + GList *allowed_senders; 8.14 + GList *denied_senders; 8.15 + GList *allowed_recipients; 8.16 + GList *denied_recipients; 8.17 8.18 interface *mail_host; 8.19 gchar *wrapper; 8.20 @@ -390,7 +388,6 @@ 8.21 gboolean addr_is_delivered_children(address * addr); 8.22 gboolean addr_is_finished_children(address * addr); 8.23 gchar *addr_string(address * addr); 8.24 -gint addr_match(address * addr1, address * addr2); 8.25 8.26 /* accept.c */ 8.27 accept_error accept_message(FILE * in, message * msg, guint flags); 8.28 @@ -493,9 +490,8 @@ 8.29 gboolean route_strip_msgout(connect_route * route, msg_out * msgout); 8.30 msg_out *route_prepare_msgout(connect_route * route, msg_out * msgout); 8.31 GList *route_msgout_list(connect_route * route, GList * msgout_list); 8.32 -gboolean route_is_allowed_return_path(connect_route * route, address * ret_path); 8.33 -gboolean route_is_allowed_mail_local(connect_route * route, address * ret_path); 8.34 -void msg_rcptlist_route(connect_route * route, GList * rcpt_list, GList ** p_rcpt_list, GList ** p_non_rcpt_list); 8.35 +gboolean route_sender_is_allowed(connect_route * route, address * ret_path); 8.36 +void route_split_rcpts(connect_route * route, GList * rcpt_list, GList ** p_rcpt_list, GList ** p_non_rcpt_list); 8.37 8.38 /* tables.c */ 8.39 table_pair *create_pair(gchar * key, gpointer value);
9.1 --- a/src/route.c Mon Apr 25 15:17:30 2011 +0200 9.2 +++ b/src/route.c Thu Apr 28 09:55:06 2011 +0200 9.3 @@ -238,21 +238,34 @@ 9.4 } 9.5 9.6 static gint 9.7 -_g_list_addrcmp(gconstpointer a, gconstpointer b) 9.8 +_g_list_addrcmp(gconstpointer pattern, gconstpointer addr) 9.9 { 9.10 - return addr_match((address *) a, (address *) b); 9.11 + int res; 9.12 + address* patternaddr = (address*) pattern; 9.13 + address* stringaddr = (address*) addr; 9.14 + 9.15 + DEBUG(6) debugf("_g_list_addrcmp: pattern `%s' `%s' on string `%s' `%s'\n", 9.16 + patternaddr->local_part, patternaddr->domain, 9.17 + stringaddr->local_part, stringaddr->domain); 9.18 + /* TODO: check if we should match here dependent on caseless_matching */ 9.19 + res = fnmatch(patternaddr->local_part, stringaddr->local_part, 0); 9.20 + if (res != 0) { 9.21 + DEBUG(6) debugf("_g_list_addrcmp: ... failed on local_part\n"); 9.22 + return res; 9.23 + } 9.24 + res = fnmatch(patternaddr->domain, stringaddr->domain, FNM_CASEFOLD); 9.25 + DEBUG(6) debugf("_g_list_addrcmp: ... %s\n", (res==0) ? "matched" : "failed on domain"); 9.26 + return res; 9.27 } 9.28 9.29 gboolean 9.30 -route_is_allowed_return_path(connect_route * route, address * ret_path) 9.31 +route_sender_is_allowed(connect_route * route, address * ret_path) 9.32 { 9.33 - if (route->not_allowed_return_paths != NULL) { 9.34 - if (g_list_find_custom(route->not_allowed_return_paths, ret_path, _g_list_addrcmp) != NULL) { 9.35 - return FALSE; 9.36 - } 9.37 + if (route->denied_senders && g_list_find_custom(route->denied_senders, ret_path, _g_list_addrcmp)) { 9.38 + return FALSE; 9.39 } 9.40 - if (route->allowed_return_paths != NULL) { 9.41 - if (g_list_find_custom(route->allowed_return_paths, ret_path, _g_list_addrcmp) != NULL) { 9.42 + if (route->allowed_senders) { 9.43 + if (g_list_find_custom(route->allowed_senders, ret_path, _g_list_addrcmp)) { 9.44 return TRUE; 9.45 } else { 9.46 return FALSE; 9.47 @@ -261,49 +274,25 @@ 9.48 return TRUE; 9.49 } 9.50 9.51 -static gint 9.52 -_g_list_strcmp(gconstpointer a, gconstpointer b) 9.53 -{ 9.54 - return (gint) strcmp(a, b); 9.55 -} 9.56 - 9.57 -gboolean 9.58 -route_is_allowed_mail_local(connect_route * route, address * ret_path) 9.59 -{ 9.60 - gchar *loc_part = ret_path->local_part; 9.61 - 9.62 - if (route->not_allowed_mail_locals != NULL) { 9.63 - if (g_list_find_custom(route->not_allowed_mail_locals, loc_part, _g_list_strcmp) != NULL) 9.64 - return FALSE; 9.65 - } 9.66 - if (route->allowed_mail_locals != NULL) { 9.67 - if (g_list_find_custom(route->allowed_mail_locals, loc_part, _g_list_strcmp) != NULL) 9.68 - return TRUE; 9.69 - else 9.70 - return FALSE; 9.71 - } 9.72 - return TRUE; 9.73 -} 9.74 - 9.75 /* 9.76 Make lists of matching/not matching rcpts. 9.77 Local domains are NOT regared here, these should be sorted out previously 9.78 */ 9.79 void 9.80 -msg_rcptlist_route(connect_route * route, GList * rcpt_list, GList ** p_rcpt_list, GList ** p_non_rcpt_list) 9.81 +route_split_rcpts(connect_route * route, GList * rcpt_list, GList ** p_rcpt_list, GList ** p_non_rcpt_list) 9.82 { 9.83 GList *tmp_list = NULL; 9.84 /* sort out those domains that can be sent over this connection: */ 9.85 - if (route->allowed_rcpt_domains) { 9.86 - DEBUG(5) debugf("testing for route->allowed_rcpt_domains\n"); 9.87 - split_rcpts(rcpt_list, route->allowed_rcpt_domains, NULL, &tmp_list, p_non_rcpt_list); 9.88 + if (route->allowed_recipients) { 9.89 + DEBUG(5) debugf("testing for route->allowed_recipients\n"); 9.90 + split_rcpts(rcpt_list, route->allowed_recipients, NULL, &tmp_list, p_non_rcpt_list); 9.91 } else { 9.92 - DEBUG(5) debugf("route->allowed_rcpt_domains == NULL\n"); 9.93 + DEBUG(5) debugf("route->allowed_recipients == NULL\n"); 9.94 tmp_list = g_list_copy(rcpt_list); 9.95 } 9.96 9.97 /* sort out those domains that cannot be sent over this connection: */ 9.98 - split_rcpts(tmp_list, route->not_allowed_rcpt_domains, NULL, p_non_rcpt_list, p_rcpt_list); 9.99 + split_rcpts(tmp_list, route->denied_recipients, NULL, p_non_rcpt_list, p_rcpt_list); 9.100 g_list_free(tmp_list); 9.101 } 9.102