chiark
/
gitweb
/
~mdw
/
odin-cgi
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
lib/Odin.pm: Provide substitutions on mail recipient addresses.
[odin-cgi]
/
lib
/
Odin.pm
diff --git
a/lib/Odin.pm
b/lib/Odin.pm
index a575e83cc4e06e839f607b02384089ff06ed3cd5..90f1dc14921c4114211cb31214365a8b29b055d1 100644
(file)
--- a/
lib/Odin.pm
+++ b/
lib/Odin.pm
@@
-574,7
+574,7
@@
sub gen_redir_name ($$) {
sub qualify_recip ($) {
my ($r) = @_;
sub qualify_recip ($) {
my ($r) = @_;
- return $r =~ /\@/ || !defined $MAIL_QUALDOM ? $r : "$r\@
$MAIL_QUALDOM
";
+ return $r =~ /\@/ || !defined $MAIL_QUALDOM ? $r : "$r\@
\%d
";
}
sub check_fixup_redir ($) {
}
sub check_fixup_redir ($) {
@@
-586,6
+586,13
@@
sub check_fixup_redir ($) {
}
}
}
}
+sub subst_recip ($$) {
+ my ($l, $r) = @_;
+ my %d = ('%' => '%', 'l' => $l, 'd' => $MAIL_QUALDOM);
+ $r =~ s{%([%a-z])}{$d{$1} // fail "undefined substitution `\%$1'"}eg;
+ return $r;
+}
+
sub new_redir ($$\%;$) {
my ($dom, $gen, $r, $n) = @_;
my $db = open_db;
sub new_redir ($$\%;$) {
my ($dom, $gen, $r, $n) = @_;
my $db = open_db;
@@
-600,7
+607,7
@@
sub new_redir ($$\%;$) {
insert_record $db, "odin_mailredir",
lpart => $l, dom => $dom, st => 'live',
owner => $WHO, creator => $WHO,
insert_record $db, "odin_mailredir",
lpart => $l, dom => $dom, st => 'live',
owner => $WHO, creator => $WHO,
- recip =>
$r->{recip} // qualify_recip $Odin::WHO
,
+ recip =>
subst_recip($l, $r->{recip} // qualify_recip $Odin::WHO)
,
expire => $r->{expire} // -1,
comment => $r->{comment} // "";
push @l, $l;
expire => $r->{expire} // -1,
comment => $r->{comment} // "";
push @l, $l;
@@
-688,7
+695,8
@@
sub modify_redir ($\%@) {
WHERE lpart = ? AND dom = ? AND owner = ?", undef,
$l, $dom, $WHO);
if (!defined $recip) { Odin::fail "unknown local part `$l'"; }
WHERE lpart = ? AND dom = ? AND owner = ?", undef,
$l, $dom, $WHO);
if (!defined $recip) { Odin::fail "unknown local part `$l'"; }
- elsif ($recip eq "") { $r{recip} //= qualify_recip $WHO; }
+ elsif ($recip eq "" || defined $r{recip})
+ { $r{recip} = subst_recip $l, $r{recip} // qualify_recip $WHO; }
if ($st ne "live") { $r{st} = "live"; $r{expire} //= -1; }
my @var = ();
my @val = ();
if ($st ne "live") { $r{st} = "live"; $r{expire} //= -1; }
my @var = ();
my @val = ();