supporters/scripts/add-postal-address.plx
2017-01-11 12:27:25 -05:00

52 lines
1.2 KiB
Perl

#!/usr/bin/perl
use strict;
use warnings;
use DBI;
use Encode qw(encode decode);
use Supporters;
binmode STDIN, ":utf8";
binmode STDOUT, ":utf8";
if (@ARGV != 1 and @ARGV !=2) {
print STDERR "usage: $0 <SUPPORTERS_SQLITE_DB_FILE> <VERBOSITY_LEVEL>\n";
exit 1;
}
my($SUPPORTERS_SQLITE_DB_FILE, $VERBOSE) = @ARGV;
$VERBOSE = 0 if not defined $VERBOSE;
my $dbh = DBI->connect("dbi:SQLite:dbname=$SUPPORTERS_SQLITE_DB_FILE", "", "",
{ RaiseError => 1, sqlite_unicode => 1 })
or die $DBI::errstr;
print "Supporter Id: ";
my $supporterId = <STDIN>;
chomp $supporterId;
print "postal Address (. to end):\n";
my $postal = "";
while (my $line = <STDIN>) {
last if $line =~ /^\s*\.\s*$/;
$postal .= $line;
}
print "Postal Address Type: ";
my $postalType = <STDIN>;
chomp $postalType;
print "Preferred (0 or 1): ";
my $preferred = <STDIN>;
chomp $preferred;
my $sp = new Supporters($dbh, [ "none" ]);
$sp->addPostalAddress($supporterId, $postal, $postalType);
print "Preferred postal address was: ", $sp->getPreferredPostalAddress($supporterId), "\n";
if ($preferred) {
$sp->setPreferredPostalAddress($supporterId, $postal);
print "Preferred postal address is now: ", $sp->getPreferredPostalAddress($supporterId), "\n";
}