diff options
author | Stefan Kangas <skangas@skangas.se> | 2011-03-21 22:24:24 +0100 |
---|---|---|
committer | Stefan Kangas <skangas@skangas.se> | 2011-03-21 22:24:24 +0100 |
commit | 7a522692d79d68d276fad9edf233530f68dadb7e (patch) | |
tree | 1b40f56a2cd8691817c07d2350320880b5a68a29 /fripost-newalias | |
parent | 701456b6047b1d698ee3a8173249afaf2679e20f (diff) |
Send confirmation when adding new alias
Diffstat (limited to 'fripost-newalias')
-rwxr-xr-x | fripost-newalias | 57 |
1 files changed, 47 insertions, 10 deletions
diff --git a/fripost-newalias b/fripost-newalias index fb9acec..ecfa4bf 100755 --- a/fripost-newalias +++ b/fripost-newalias @@ -1,8 +1,9 @@ #!/usr/bin/perl use 5.010_000; -use warnings; use strict; +use warnings; +use utf8; =head1 NAME @@ -18,13 +19,17 @@ fripost-newalias GOTO FROM... use FindBin qw($Bin); use lib "$Bin/lib"; -use Data::Dumper; +use Encode qw(encode); use Email::Valid; use Fripost::Password; use Fripost::Prompt; use Fripost::Schema; use IO::Prompt; use Getopt::Long; +use MIME::Base64; +use MIME::Lite; +use MIME::QuotedPrint; +use Template; use YAML::Syck; ## Get command line options @@ -48,11 +53,6 @@ my @addr = @ARGV; $goto //= prompt_username("Alias goto address: "); @addr || push @addr, prompt "Alias address: "; -if ($conf->{pretend}) { - say "Nothing to do since we are pretending..."; - exit 0; -} - # Show goto adress say "goto adress: $goto"; @@ -84,15 +84,52 @@ for my $addr (@addr) { goto => $goto, domain => (split /\@/, $addr)[1], }); - $db_alias->insert; - - say "New alias added from $addr to $goto."; + if (!$conf->{pretend}) { + $db_alias->insert; + say "New alias added from $addr to $goto."; + } else { + say "Pretending, will not add alias." + } } else { say "There already exists an alias for $addr."; } } +### Prepare sending emails +my $tt = Template->new({ + INCLUDE_PATH => "$Bin/templ", + INTERPOLATE => 1, +}) || die "$Template::ERROR\n"; + +my $msg = MIME::Lite->new( + From => encode('MIME-Q', 'Friposts administratörer') . ' <admin@fripost.org>', + Subject => encode('MIME-Q', 'Nya alias till din inkorg'), + Encoding => 'quoted-printable', +); + +{ + my ($vars, $data); + $vars = { + addrs => \@addr, + }; + + $tt->process('new_alias.tt', $vars, \$data) + || die $tt->error(), '\n'; + $msg->data($data); + + $msg->replace(To => $goto); + + if (!$conf->{pretend}) { + confirm_or_abort("Send confirmation? "); + $msg->send; + say "Sent verification."; + } + else { + say "Pretending, will not send verification."; + } +} + =head1 AUTHOR Stefan Kangas C<< <skangas at skangas.se> >> |