fsfe-website/cgi-bin/weborder.pl

160 lines
5.6 KiB
Perl
Executable File

#!/usr/bin/perl
use CGI;
use POSIX qw(strftime);
use Digest::SHA1 qw(sha1_hex);
my $query = new CGI;
if ($query->param("url")) {
print "Content-type: text/html\n\n";
print "<p>Invalid input!</p>\n";
exit;
}
my $name = $query->param("name");
my $address = $query->param("address");
my $email = $query->param("email");
my $phone = $query->param("phone");
my $language = $query->param("language");
# Remove all parameters except for items and prices.
$query->delete("url", "name", "address", "email", "phone", "language");
my $lang = substr($language, 0, 2);
# -----------------------------------------------------------------------------
# Calculate total amount and check for empty orders
# -----------------------------------------------------------------------------
if (!$name) {
print "Content-type: text/html\n\n";
print "<p>Please enter your name!</p>\n";
exit;
}
if (!$email) {
print "Content-type: text/html\n\n";
print "<p>Please enter your email address!</p>\n";
exit;
}
my $empty = 1;
my $amount = 0;
foreach $item ($query->param) {
$value = $query->param($item);
if (not $item =~ /^_/ and $value) {
my $price = $query->param("_$item");
$amount += $value * $price;
if ($item ne "shipping") {
$empty = 0;
}
}
}
if ($empty) {
print "Content-type: text/html\n\n";
print "<p>No items selected!</p>\n";
exit;
}
if ($amount > 999) {
print "Content-type: text/html\n\n";
print "<p>Sorry, total amount too large.</p>\n";
exit;
}
my $amount_f = sprintf("%.2f", $amount);
my $amount100 = $amount * 100;
# -----------------------------------------------------------------------------
# Create payment reference for this order
# -----------------------------------------------------------------------------
my $date = strftime("%j", localtime);
my $time = strftime("%s", localtime);
my $reference = "MP" . $date . substr($time, -4) . sprintf("%03u", $amount);
# -----------------------------------------------------------------------------
# Generate mail to office
# -----------------------------------------------------------------------------
open(MAIL, "|/usr/lib/sendmail -t -f contact\@fsfe.org");
print MAIL "From: $name <$email>\n";
print MAIL "To: contact\@fsfe.org\n";
print MAIL "X-OTRS-Queue: Finance::Merchandise Orders\n";
print MAIL "X-OTRS-DynamicField-OrderID: $reference\n";
print MAIL "X-OTRS-DynamicField-OrderAmount: $amount\n";
print MAIL "X-OTRS-DynamicField-OrderLanguage: $language\n";
print MAIL "X-OTRS-DynamicField-OrderState: order\n";
print MAIL "Content-Transfer-Encoding: 8bit\n";
print MAIL "Content-Type: text/plain; charset=\"UTF-8\"\n";
print MAIL "Subject: $reference\n\n";
print MAIL "$name\n";
print MAIL "$address\n";
print MAIL "Phone: $phone\n\n";
foreach $item ($query->param) {
$value = $query->param($item);
if (not $item =~ /^_/ and $value) {
my $price = $query->param("_$item");
printf MAIL "%-30s %3u x %5.2f = %6.2f\n", $item, $value, $price, $value * $price;
}
}
print MAIL "---------------------------------------------------\n";
printf MAIL "Total amount € %6.2f\n", $amount;
print MAIL "===================================================\n";
close MAIL;
# -----------------------------------------------------------------------------
# Generate form for ConCardis payment
# -----------------------------------------------------------------------------
my $passphrase = "Only4TestingPurposes";
my $shastring =
"ACCEPTURL=http://fsfe.org/order/thankyou.$lang.html$passphrase" .
"AMOUNT=$amount100$passphrase" .
"CANCELURL=http://fsfe.org/order/cancel.$lang.html$passphrase" .
"CN=$name$passphrase" .
"CURRENCY=EUR$passphrase" .
"EMAIL=$email$passphrase" .
"LANGUAGE=$language$passphrase" .
"ORDERID=$reference$passphrase" .
"PMLISTTYPE=2$passphrase" .
"PSPID=40F00871$passphrase" .
"TP=https://fsfe.org/order/tmpl-concardis.$lang.html$passphrase";
my $shasum = uc(sha1_hex($shastring));
my $form = " <!-- payment parameters -->\n" .
" <input type=\"hidden\" name=\"PSPID\" value=\"40F00871\"/>\n" .
" <input type=\"hidden\" name=\"orderID\" value=\"$reference\"/>\n" .
" <input type=\"hidden\" name=\"amount\" value=\"$amount100\"/>\n" .
" <input type=\"hidden\" name=\"currency\" value=\"EUR\"/>\n" .
" <input type=\"hidden\" name=\"language\" value=\"$language\"/>\n" .
" <input type=\"hidden\" name=\"CN\" value=\"$name\"/>\n" .
" <input type=\"hidden\" name=\"EMAIL\" value=\"$email\"/>\n" .
" <!-- interface template -->\n" .
" <input type=\"hidden\" name=\"TP\" value=\"https://fsfe.org/order/tmpl-concardis.$lang.html\"/>\n" .
" <input type=\"hidden\" name=\"PMListType\" value=\"2\"/>\n" .
" <!-- post-payment redirection -->\n" .
" <input type=\"hidden\" name=\"accepturl\" value=\"http://fsfe.org/order/thankyou.$lang.html\"/>\n" .
" <input type=\"hidden\" name=\"cancelurl\" value=\"http://fsfe.org/order/cancel.$lang.html\"/>\n" .
" <!-- SHA1 signature -->\n" .
" <input type=\"hidden\" name=\"SHASign\" value=\"$shasum\"/>";
# -----------------------------------------------------------------------------
# Lead user to "thankyou" page
# -----------------------------------------------------------------------------
print "Content-type: text/html\n\n";
open TEMPLATE, "/home/www/html/global/order/tmpl-thankyou." . $lang . ".html";
while (<TEMPLATE>) {
s/:AMOUNT:/$amount_f/g;
s/:REFERENCE:/$reference/g;
s/:FORM:/$form/g;
print;
}
close TEMPLATE;