Listing 2.
#!/usr/bin/perl -w
use strict;
use diagnostics;
available from https://www.perl.com/CPAN/
use CGI;
use Mysql;
# This should match the mail program on your
# system.
my $mailprog = '/usr/lib/sendmail';
# Create an instance of CGI
my $query = new CGI;
# Send an appropriate MIME header
print $query->header("text/html");
# Grab values from some
my $sender_name = $query->param("sender_name");
my $sender_email = $query->param("sender_email");
my $recipient_name = $query->param
("recipient_name");
my $recipient_email = $query->
param("recipient_email");
my $graphic_name = $query->param("graphic_name");
my $postcard_text =
$query->param("postcard_text");
# Get the lowest digits from the time of day,
# which should serve as a relatively unique ID
# number
my $id_number = time & 0xFFFFF & $$;
# Connect via Unix sockets to the database on
# this server
my $dbh = Mysql->connect("localhost", "test");
# Build up our SQL command
my $command = "";
$command = "insert into postcards ";
$command .= " (id_number, sender_name, ";
$command .= "sender_email, recipient_name, ";
$command .= "recipient_email, graphic_name, ";
$command .= "postcard_text) ";
$command .= "values ";
$command .= "($id_number, \"$sender_name\",
$command .= "\"$sender_email\", ";
$command .= "\"$recipient_name\",
$command .= "\"$recipient_email\", ";
$command .= "\"$graphic_name\",
$command .= "\"$postcard_text\") ";
# Uncomment for debugging
# print "<P>SQL command: <B>$command</B></P>\n";
# Send the query
my $sth = $dbh->query($command);
# Make sure that $sth returned reasonably
die "Error with command \"$command\""
unless (defined $sth);
#---------------------------------------------------------------
# Send a postcard notification via e-mail
open (MAIL, "|$mailprog $recipient_email") ||
die "Can't open $mailprog!\n";
# Headers in the mail message
print MAIL "From: $sender_email\n";
print MAIL "To: $recipient_email\n";
print MAIL "Reply-to: $sender_email ";
print MAIL "($sender_name)\n";
print MAIL "Subject: Postcard waiting for ";
print MAIL "you\n\n";
# Body of the mail message
print MAIL "A postcard from $sender_name ";
print MAIL "($sender_email) is waiting for";
print MAIL "you at the URL \n\n";
# the following line wraps due to column width
print MAIL "https://www.oursitename.com/cgi-bin/show-postcard.pl?$id_number\n";
close (MAIL);
#--------------------------------------------------------------
# Begin the HTML output
print $query->start_html(-title => "Thanks!");
print "<P>Thanks for sending a postcard!</P>\n";
# End the HTML
print $query->end_html;
exit;