diff options
Diffstat (limited to 'usr.sbin')
-rw-r--r-- | usr.sbin/smtpd/makemap.8 | 8 | ||||
-rw-r--r-- | usr.sbin/smtpd/parse.y | 31 | ||||
-rw-r--r-- | usr.sbin/smtpd/smtpd.conf.5 | 29 | ||||
-rw-r--r-- | usr.sbin/smtpd/smtpd.h | 7 |
4 files changed, 38 insertions, 37 deletions
diff --git a/usr.sbin/smtpd/makemap.8 b/usr.sbin/smtpd/makemap.8 index 1810e9a3d54..25fa0692bbf 100644 --- a/usr.sbin/smtpd/makemap.8 +++ b/usr.sbin/smtpd/makemap.8 @@ -1,4 +1,4 @@ -.\" $OpenBSD: makemap.8,v 1.15 2011/10/10 21:06:06 gilles Exp $ +.\" $OpenBSD: makemap.8,v 1.16 2012/05/12 21:49:31 gilles Exp $ .\" .\" Copyright (c) 2009 Jacek Masiulaniec <jacekm@openbsd.org> .\" Copyright (c) 2008-2009 Gilles Chechade <gilles@openbsd.org> @@ -15,7 +15,7 @@ .\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF .\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. .\" -.Dd $Mdocdate: October 10 2011 $ +.Dd $Mdocdate: May 12 2012 $ .Dt MAKEMAP 8 .Os .Sh NAME @@ -104,8 +104,8 @@ In addition to adding an entry to the virtual map, one must add a filter rule that accepts mail for virtual domains, for example: .Bd -literal -offset indent -map "vdomains" { source db "/etc/mail/vdomains.db" } -accept for virtual "vdomains" deliver to mbox +map "vdomains" source db "/etc/mail/vdomains.db" +accept for virtual map "vdomains" deliver to mbox .Ed .Sh FILES .Bl -tag -width "/etc/mail/aliasesXXX" -compact diff --git a/usr.sbin/smtpd/parse.y b/usr.sbin/smtpd/parse.y index a27c515378b..dcebfcd5663 100644 --- a/usr.sbin/smtpd/parse.y +++ b/usr.sbin/smtpd/parse.y @@ -1,4 +1,4 @@ -/* $OpenBSD: parse.y,v 1.86 2012/05/12 18:41:10 gilles Exp $ */ +/* $OpenBSD: parse.y,v 1.87 2012/05/12 21:49:31 gilles Exp $ */ /* * Copyright (c) 2008 Gilles Chehade <gilles@openbsd.org> @@ -123,9 +123,9 @@ typedef struct { %token AS QUEUE INTERVAL SIZE LISTEN ON ALL PORT EXPIRE %token MAP HASH LIST SINGLE SSL SMTPS CERTIFICATE -%token DB PLAIN EXTERNAL DOMAIN SOURCE +%token DB PLAIN DOMAIN SOURCE %token RELAY VIA DELIVER TO MAILDIR MBOX HOSTNAME -%token ACCEPT REJECT INCLUDE NETWORK ERROR MDA FROM FOR +%token ACCEPT REJECT INCLUDE ERROR MDA FROM FOR %token ARROW ENABLE AUTH TLS LOCAL VIRTUAL TAG ALIAS FILTER %token <v.string> STRING %token <v.number> NUMBER @@ -436,7 +436,6 @@ mapsource : PLAIN STRING { >= sizeof(map->m_config)) err(1, "pathname too long"); } - | EXTERNAL { map->m_src = S_EXT; } ; mapopt : SOURCE mapsource { } @@ -729,16 +728,7 @@ alias : ALIAS STRING { $$ = $2; } | /* empty */ { $$ = NULL; } ; -condition : NETWORK mapref { - struct cond *c; - - if ((c = calloc(1, sizeof *c)) == NULL) - fatal("out of memory"); - c->c_type = C_NET; - c->c_map = $2; - $$ = c; - } - | DOMAIN mapref alias { +condition : DOMAIN mapref alias { struct cond *c; struct map *m; @@ -757,21 +747,20 @@ condition : NETWORK mapref { c->c_map = $2; $$ = c; } - | VIRTUAL STRING { + | VIRTUAL mapref { struct cond *c; struct map *m; - if ((m = map_findbyname($2)) == NULL) { - yyerror("no such map: %s", $2); - free($2); + m = map_find($2); + if (m->m_src == S_NONE) { + yyerror("virtual parameter MUST be a map"); YYERROR; } - free($2); if ((c = calloc(1, sizeof *c)) == NULL) fatal("out of memory"); c->c_type = C_VDOM; - c->c_map = m->m_id; + c->c_map = $2; $$ = c; } | LOCAL alias { @@ -1209,7 +1198,6 @@ lookup(char *s) { "domain", DOMAIN }, { "enable", ENABLE }, { "expire", EXPIRE }, - { "external", EXTERNAL }, { "filter", FILTER }, { "for", FOR }, { "from", FROM }, @@ -1224,7 +1212,6 @@ lookup(char *s) { "map", MAP }, { "mbox", MBOX }, { "mda", MDA }, - { "network", NETWORK }, { "on", ON }, { "plain", PLAIN }, { "port", PORT }, diff --git a/usr.sbin/smtpd/smtpd.conf.5 b/usr.sbin/smtpd/smtpd.conf.5 index 944d3f118b3..d88df7166b0 100644 --- a/usr.sbin/smtpd/smtpd.conf.5 +++ b/usr.sbin/smtpd/smtpd.conf.5 @@ -1,4 +1,4 @@ -.\" $OpenBSD: smtpd.conf.5,v 1.50 2012/05/12 18:41:10 gilles Exp $ +.\" $OpenBSD: smtpd.conf.5,v 1.51 2012/05/12 21:49:31 gilles Exp $ .\" .\" Copyright (c) 2008 Janne Johansson <jj@openbsd.org> .\" Copyright (c) 2009 Jacek Masiulaniec <jacekm@dobremiasto.net> @@ -222,11 +222,17 @@ specified in CIDR notation. .Pp Next comes the selection based on the domain the message is sent to: .Bl -tag -width Ds -.It Ic for all +.It Xo +.Ic for all +.Op Ic alias Ar aliases +.Xc Make the rule match regardless of the domain it is sent to. +If specified, +.Ar aliases +is used for looking up alternative destinations for all addresses. .It Xo .Ic for domain Ar domain -.Op Ic alias Ar map +.Op Ic alias Ar aliases .Xc This rule applies to mail destined for the specified .Ar domain . @@ -239,10 +245,21 @@ accept for domain "*.example.com" deliver to mbox .Ed .Pp If specified, -.Ar map +.Ar aliases is used for looking up alternative destinations for addresses in this .Ar domain . .It Xo +.Ic for domain map Ar domains +.Op Ic alias Ar aliases +.Xc +This rule applies to mail destined to domains part of the map +.Ar domains . +.Pp +If specified, +.Ar aliases +is used for looking up alternative destinations for addresses in these +.Ar domains . +.It Xo .Ic for local .Op Ic alias Ar map .Xc @@ -251,10 +268,10 @@ This rule applies to mail destined to and to the server's fully qualified domain name, as returned by .Xr hostname 1 . -.It Ic for virtual Ar map +.It Ic for virtual map Ar vmap This rule applies to mail destined for the virtual domains specified in the map -.Ar map . +.Ar vmap . For an example of how to configure a virtual map, see .Xr makemap 8 . .El diff --git a/usr.sbin/smtpd/smtpd.h b/usr.sbin/smtpd/smtpd.h index 6b0b605cce2..98483b7256a 100644 --- a/usr.sbin/smtpd/smtpd.h +++ b/usr.sbin/smtpd/smtpd.h @@ -1,4 +1,4 @@ -/* $OpenBSD: smtpd.h,v 1.291 2012/05/12 18:41:10 gilles Exp $ */ +/* $OpenBSD: smtpd.h,v 1.292 2012/05/12 21:49:31 gilles Exp $ */ /* * Copyright (c) 2008 Gilles Chehade <gilles@openbsd.org> @@ -233,11 +233,8 @@ struct peer { enum map_src { S_NONE, - S_DYN, - S_DNS, S_PLAIN, - S_DB, - S_EXT + S_DB }; enum map_kind { |