require HTTP::BrowserDetect;
require HTTP::Negotiate;
require Geo::IP;
+require CGI;
# Undo 'www/engine/httpd-restart' as it may use obsolete Perl for 'mod_perl'
do { $W->{$_}=0 if !defined $W->{$_}; } for ("detect_ent");
do { $W->{$_}=0 if !defined $W->{$_}; } for ("detect_js");
do { $W->{$_}=1 if !defined $W->{$_}; } for ("have_css"); # AFAIK it does not hurt anyone.
+ do { $W->{$_}=1 if !defined $W->{$_}; } for ("footer");
do { $W->{$_}=1 if !defined $W->{$_}; } for ("footer_delimit");
+ do { $W->{$_}=1 if !defined $W->{$_}; } for ("footer_mailme");
do { $W->{$_}=1 if !defined $W->{$_}; } for ("footer_ids");
do { $W->{$_}=1 if !defined $W->{$_}; } for ("indexme");
do { $W->{$_}="" if !defined $W->{$_}; } for ("head");
do { $W->{$_}="" if !defined $W->{$_}; } for ("head_css");
+ my $footer_any=0;
+ for (qw(footer_mailme footer_ids)) {
+ $W->{$_}=0 if !$W->{"footer"};
+ $footer_any=1 if $W->{$_};
+ }
+ $W->{"footer"}=0 if !$footer_any;
+ $W->{"footer_delimit"}=0 if !$W->{"footer"};
+
$W->{"r"}=Apache->request();
$W->{"QUERY_STRING"}=$W->{"r"}->args() || "";
}
$W->{"QUERY_STRING"}=~s/([&])amp;/$1/g;
$W->{"r"}->args($W->{"QUERY_STRING"});
- $W->{"args"}={ $W->{"r"}->args() };
+ $ENV{"QUERY_STRING"}=$W->{"QUERY_STRING"};
+ # Do not: $W->{"r"}->args()
+ # as it parses only QUERY_STRING (not POST data).
+ $W->{"args"}={ CGI->new()->Vars() };
do { $W->{$_}=$ENV{"HTTP_ACCEPT"} if !defined $W->{$_}; } for ("accept");
do { $W->{$_}=$ENV{"HTTP_USER_AGENT"} if !defined $W->{$_}; } for ("user_agent");
while (my($name,$regex)=each(%tmpl)) {
my $name_html="Parametr <span class=\"quote\">".CGI::escapeHTML($name)."</span>";
my $val=$W->{"args"}{$name};
- fatal "$name_html does not match required regex <span class=\"quote\">".CGI::escapeHTML($regex)."</span>"
+ fatal "$name_html <span class=\"quote\">".CGI::escapeHTML($val)."</span>"
+ ." does not match required regex <span class=\"quote\">".CGI::escapeHTML($regex)."</span>"
if defined $val && $val!~/$regex/;
fatal "$name_html is required"
if !defined $val;
{
exit 1 if $W->{"footer_passed"}++; # deadlock prevention:
- if ($W->{"footer_ids"}) {
- print vskip if $W->{"footer_delimit"};
- print '<hr /><p class="cvs-id">';
+ print vskip if $W->{"footer_delimit"};
+
+ print "<hr />\n" if $W->{"footer"};
+
+ if ($W->{"footer_mailme"}) {
+ print '<form action="'.$W->{"top_dir"}.'/SendMsg.pl" method="post" onsubmit="'
+ ."this.elements['msgscript'].value=this.elements['msghtml'].value;"
+ ."this.elements['msghtml'].value='';"
+ ."this.submit();"
+ .'">'."\n";
+ print '<p align="center">'."\n";
+ print '<input name="msgscript" type="hidden" />'."\n";
+ print '<input name="msghtml" type="text" size="32" alt="Message" />'."\n";
+ print '<input name="submit" type="submit" value="Quick Note" />'."\n";
+ print '</p>'."\n";
+ print '</form>'."\n";
+ }
+ if ($W->{"footer_ids"}) {
+ print '<p class="cvs-id">';
print join("<br />\n",map({ my $package=$_;
my $cvs_id=(eval('$'.$package."::CVS_ID")
# || $package # debug
elsif ($W->{"have_ent"}) # ent client
{ $r.=$urlent; }
else # unknown client, &CGI::escapeHTML should not be needed here
- { $r.=CGI::escapeHTML("http://".$W->{"r"}->hostname()."/redirect.pl?location=".uri_escape($url)); }
+ { $r.=CGI::escapeHTML("http://".$W->{"r"}->hostname()."/Redirect.pl?location=".uri_escape($url)); }
$r.='">'.$contents.'</a>';
if ($args{"size"} && url_is_local($url) && $url=~/[.](?:gz|rpm|zip|deb)/) { # Downloadable?
if (!-r $url)
# $ENV{"CLIENT_CHARSET"} ignored (mod_czech support dropped!)
my $client_charset=$W->{"force_charset"} || "us-ascii";
header("Content-Style-Type"=>"text/css");
+ header("Content-Script-Type"=>"text/javascript");
while (my($key,$val)=each(%{$W->{"headers"}})) {
$W->{"r"}->header_out($key,$val);