diff options
author | justint <justint@web> | 2011-03-02 03:00:28 +0000 |
---|---|---|
committer | Joey Hess <joey@kitenet.net> | 2011-03-02 03:00:28 +0000 |
commit | a91bd978d851820d4f9f5ab3294eab77065c073d (patch) | |
tree | 54c78740530b3760df1acc52e6c17adc27f3b976 /doc/plugins | |
parent | b156dbdcc25aa5f1e8124d0ae14d9aa75835b606 (diff) | |
download | ikiwiki-a91bd978d851820d4f9f5ab3294eab77065c073d.tar ikiwiki-a91bd978d851820d4f9f5ab3294eab77065c073d.tar.gz |
Diffstat (limited to 'doc/plugins')
-rw-r--r-- | doc/plugins/contrib/justlogin.mdwn | 61 |
1 files changed, 24 insertions, 37 deletions
diff --git a/doc/plugins/contrib/justlogin.mdwn b/doc/plugins/contrib/justlogin.mdwn index b9fc6f674..ef3d1bfff 100644 --- a/doc/plugins/contrib/justlogin.mdwn +++ b/doc/plugins/contrib/justlogin.mdwn @@ -1,4 +1,4 @@ -This plugin is still in development. Currently it does bring up the login page and the login page does, with proper credentials, log in the user, but the returning page errors. +This plugin is still in development. Currently it does bring up the login page and the login page does, with proper credentials, log in the user, but the returning page goes to prefs. I have no idea why. Place this code into a page: @@ -8,11 +8,8 @@ Place this code into a page: <input type="submit" value="Login" /></form> - - This is the plugin so far: - - #!/usr/bin/perl +#!/usr/bin/perl # Bring up a login page that returns to the calling page package IkiWiki::Plugin::justlogin; @@ -21,45 +18,35 @@ This is the plugin so far: use IkiWiki 3.00; sub import { - hook(type => "sessioncgi", id => "justlogin", call => \&sessioncgi); - hook(type => "auth", id => "justlogin", call => \&auth); + hook(type => "sessioncgi", id => "justlogin", call => \&sessioncgi); } sub sessioncgi ($$) { my $q=shift; my $session=shift; - debug("jl sessioncgi1 running."); - - if ($q->param('do') eq 'justlogin') { - debug("Justlogin do=justlogin running."); - if (! defined $session->param("name") ) { - debug("Justlogin param!defined running."); - $session->param(postsignin => $ENV{HTTP_REFERER} ); - $session->param("do" => "justgoback" ); - IkiWiki::cgi_savesession($session); - IkiWiki::cgi_signin($q, $session); - exit; - } - } elsif ($session->param('do') eq 'justgoback') { - debug("jl justgoback running."); - if (! defined $session->param("name")) { - debug("Justlogin redir running."); - my $page=IkiWiki::possibly_foolish_untaint($q->param('postsignin')); - $session->clear("postsignin"); - $session->clear("do"); - IkiWiki::cgi_savesession($session); - IkiWiki::redirect($q, $page); - } - } - } - - sub auth ($$) { - # While this hook is not currently used, it needs to exist - # so ikiwiki knows that the wiki supports logins, and will - # enable the Preferences page. + debug("jl sessioncgi1 running."); + + if ($q->param("do") eq "justlogin") { + debug("jl do=justlogin running."); + if (! defined $session->param("name") ) { + debug("jl param!defined running."); + $session->param("postsignin" => $ENV{HTTP_REFERER} ); + $session->param("do" => "justgoback" ); + IkiWiki::cgi_signin($q, $session); + IkiWiki::cgi_savesession($session); + } + exit; + } elsif ($session->param("do") eq "justgoback") { + debug("jl justgoback running."); + my $page=$q->param("postsignin"); + $session->clear("postsignin"); + $session->clear("do"); + IkiWiki::cgi_savesession($session); + IkiWiki::redirect($q, $page); + exit; + } } - 1 |