Photos
Blog
Projects
vanrenterghem.biz
projects
/
git.ikiwiki.info.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
tested and seems to work
[git.ikiwiki.info.git]
/
IkiWiki
/
CGI.pm
diff --git
a/IkiWiki/CGI.pm
b/IkiWiki/CGI.pm
index 52cafade0f9f7f7ae155402464283e22c991a67d..f2a32a9581077553d5b542fde40f428c15a5e41a 100644
(file)
--- a/
IkiWiki/CGI.pm
+++ b/
IkiWiki/CGI.pm
@@
-15,13
+15,14
@@
sub printheader ($) {
if ($config{sslcookie}) {
print $session->header(-charset => 'utf-8',
-cookie => $session->cookie(-httponly => 1, -secure => 1));
if ($config{sslcookie}) {
print $session->header(-charset => 'utf-8',
-cookie => $session->cookie(-httponly => 1, -secure => 1));
- } else {
+ }
+ else {
print $session->header(-charset => 'utf-8',
-cookie => $session->cookie(-httponly => 1));
}
}
print $session->header(-charset => 'utf-8',
-cookie => $session->cookie(-httponly => 1));
}
}
-sub
showform ($$$$;@)
{
+sub
prepform
{
my $form=shift;
my $buttons=shift;
my $session=shift;
my $form=shift;
my $buttons=shift;
my $session=shift;
@@
-34,13
+35,24
@@
sub showform ($$$$;@) {
});
}
});
}
+ return $form;
+}
+
+sub showform ($$$$;@) {
+ my $form=prepform(@_);
+ shift;
+ my $buttons=shift;
+ my $session=shift;
+ my $cgi=shift;
+
printheader($session);
print misctemplate($form->title, $form->render(submit => $buttons), @_);
}
sub redirect ($$) {
my $q=shift;
printheader($session);
print misctemplate($form->title, $form->render(submit => $buttons), @_);
}
sub redirect ($$) {
my $q=shift;
- my $url=shift;
+ eval q{use URI};
+ my $url=URI->new(shift);
if (! $config{w3mmode}) {
print $q->redirect($url);
}
if (! $config{w3mmode}) {
print $q->redirect($url);
}
@@
-51,7
+63,7
@@
sub redirect ($$) {
}
sub decode_cgi_utf8 ($) {
}
sub decode_cgi_utf8 ($) {
- # decode_form_utf8 method is needed for 5.
10
+ # decode_form_utf8 method is needed for 5.
01
if ($] < 5.01) {
my $cgi = shift;
foreach my $f ($cgi->param) {
if ($] < 5.01) {
my $cgi = shift;
foreach my $f ($cgi->param) {
@@
-64,8
+76,9
@@
sub decode_form_utf8 ($) {
if ($] >= 5.01) {
my $form = shift;
foreach my $f ($form->field) {
if ($] >= 5.01) {
my $form = shift;
foreach my $f ($form->field) {
+ my @value=map { decode_utf8($_) } $form->field($f);
$form->field(name => $f,
$form->field(name => $f,
- value =>
decode_utf8($form->field($f))
,
+ value =>
\@value
,
force => 1,
);
}
force => 1,
);
}
@@
-87,9
+100,10
@@
sub needsignin ($$) {
}
}
}
}
-sub cgi_signin ($$) {
+sub cgi_signin ($$
;$
) {
my $q=shift;
my $session=shift;
my $q=shift;
my $session=shift;
+ my $returnhtml=shift;
decode_cgi_utf8($q);
eval q{use CGI::FormBuilder};
decode_cgi_utf8($q);
eval q{use CGI::FormBuilder};
@@
-105,13
+119,10
@@
sub cgi_signin ($$) {
action => $config{cgiurl},
header => 0,
template => {type => 'div'},
action => $config{cgiurl},
header => 0,
template => {type => 'div'},
- stylesheet =>
baseurl()."style.css"
,
+ stylesheet =>
1
,
);
my $buttons=["Login"];
);
my $buttons=["Login"];
- if ($q->param("do") ne "signin" && !$form->submitted) {
- $form->text(gettext("You need to log in first."));
- }
$form->field(name => "do", type => "hidden", value => "signin",
force => 1);
$form->field(name => "do", type => "hidden", value => "signin",
force => 1);
@@
-126,6
+137,11
@@
sub cgi_signin ($$) {
$form->validate;
}
$form->validate;
}
+ if ($returnhtml) {
+ $form=prepform($form, $buttons, $session, $q);
+ return $form->render(submit => $buttons);
+ }
+
showform($form, $buttons, $session, $q);
}
showform($form, $buttons, $session, $q);
}
@@
-184,7
+200,7
@@
sub cgi_prefs ($$) {
params => $q,
action => $config{cgiurl},
template => {type => 'div'},
params => $q,
action => $config{cgiurl},
template => {type => 'div'},
- stylesheet =>
baseurl()."style.css"
,
+ stylesheet =>
1
,
fieldsets => [
[login => gettext("Login")],
[preferences => gettext("Preferences")],
fieldsets => [
[login => gettext("Login")],
[preferences => gettext("Preferences")],
@@
-231,14
+247,20
@@
sub cgi_prefs ($$) {
$form->text(gettext("Preferences saved."));
}
$form->text(gettext("Preferences saved."));
}
- showform($form, $buttons, $session, $q);
+ showform($form, $buttons, $session, $q,
+ prefsurl => "", # avoid showing the preferences link
+ );
}
}
-sub cgi_custom_failure ($$) {
- my $header=shift;
+sub cgi_custom_failure ($$$) {
+ my $q=shift;
+ my $httpstatus=shift;
my $message=shift;
my $message=shift;
- print $header;
+ print $q->header(
+ -status => $httpstatus,
+ -charset => 'utf-8',
+ );
print $message;
# Internet Explod^Hrer won't show custom 404 responses
print $message;
# Internet Explod^Hrer won't show custom 404 responses
@@
-261,7
+283,7
@@
sub check_banned ($$) {
foreach my $b (@{$config{banned_users}}) {
if (pagespec_match("", $b,
foreach my $b (@{$config{banned_users}}) {
if (pagespec_match("", $b,
- ip => $
ENV{REMOTE_ADDR}
,
+ ip => $
session->remote_addr()
,
name => defined $name ? $name : "",
)) {
$banned=1;
name => defined $name ? $name : "",
)) {
$banned=1;
@@
-273,7
+295,7
@@
sub check_banned ($$) {
$session->delete();
cgi_savesession($session);
cgi_custom_failure(
$session->delete();
cgi_savesession($session);
cgi_custom_failure(
- $q
->header(-status => "403 Forbidden")
,
+ $q
, "403 Forbidden"
,
gettext("You are banned."));
}
}
gettext("You are banned."));
}
}