aboutsummaryrefslogtreecommitdiff
path: root/IkiWiki/Plugin
diff options
context:
space:
mode:
authorJoey Hess <joeyh@joeyh.name>2015-05-13 23:06:52 -0400
committerJoey Hess <joeyh@joeyh.name>2015-05-13 23:06:52 -0400
commita7bd24b7b9c55e21ee998a751fd6771b9e71cb46 (patch)
tree81ef59ba2abdf26a34aff9f913352f7ed45feada /IkiWiki/Plugin
parent95e1e51caafbb3e4b179936b6d191ca87f47d4ae (diff)
downloadikiwiki-a7bd24b7b9c55e21ee998a751fd6771b9e71cb46.tar
ikiwiki-a7bd24b7b9c55e21ee998a751fd6771b9e71cb46.tar.gz
fix up session cookie
Diffstat (limited to 'IkiWiki/Plugin')
-rw-r--r--IkiWiki/Plugin/emailauth.pm51
1 files changed, 36 insertions, 15 deletions
diff --git a/IkiWiki/Plugin/emailauth.pm b/IkiWiki/Plugin/emailauth.pm
index 3266e21ab..57100a2d7 100644
--- a/IkiWiki/Plugin/emailauth.pm
+++ b/IkiWiki/Plugin/emailauth.pm
@@ -64,7 +64,7 @@ sub email_auth ($$$$) {
});
}
- my $token=gentoken($email);
+ my $token=gentoken($email, $session);
my $template=template("emailauth.tmpl");
$template->param(
wikiname => $config{wikiname},
@@ -96,19 +96,10 @@ sub cgi ($$) {
my $email=$cgi->param('e');
my $v=$cgi->param('v');
if (defined $email && defined $v && length $email && length $v) {
- # Need to lock the wiki before getting a session.
- IkiWiki::lockwiki();
- IkiWiki::loadindex();
- my $session=IkiWiki::cgi_getsession();
-
my $token=gettoken($email);
if ($token eq $v) {
- print STDERR "SUCCESS $email!!\n";
cleartoken($email);
- $session->param(name => $email);
- my $nickname=$email;
- $nickname=~s/@.*//;
- $session->param(nickname => Encode::decode_utf8($nickname));
+ my $session=getsession($email);
IkiWiki::cgi_postsignin($cgi, $session);
}
elsif (length $token ne length $cgi->param('v')) {
@@ -123,16 +114,22 @@ sub cgi ($$) {
# Generates the token that will be used in the authurl to log the user in.
# This needs to be hard to guess, and relatively short. Generating a cgi
# session id will make it as hard to guess as any cgi session.
-sub gentoken ($) {
+#
+# Store token in userinfo; this allows the user to log in
+# using a different browser session, if it takes a while for the
+# email to get to them.
+#
+# The postsignin value from the session is also stored in the userinfo
+# to allow resuming in a different browser session.
+sub gentoken ($$) {
my $email=shift;
+ my $session=shift;
eval q{use CGI::Session};
error($@) if $@;
my $token = CGI::Session->new->id;
- # Store token in userinfo; this allows the user to log in
- # using a different browser session, if it takes a while for the
- # email to get to them.
IkiWiki::userinfo_set($email, "emailauthexpire", time+(60*60*24));
IkiWiki::userinfo_set($email, "emailauth", $token);
+ IkiWiki::userinfo_set($email, "emailauthpostsignin", defined $session->param("postsignin") ? $session->param("postsignin") : "");
return $token;
}
@@ -147,6 +144,30 @@ sub gettoken ($) {
return $val;
}
+# Generate a session to use after successful login.
+sub getsession ($) {
+ my $email=shift;
+
+ IkiWiki::lockwiki();
+ IkiWiki::loadindex();
+ my $session=IkiWiki::cgi_getsession();
+
+ my $postsignin=IkiWiki::userinfo_get($email, "emailauthpostsignin");
+ IkiWiki::userinfo_set($email, "emailauthpostsignin", "");
+ if (defined $postsignin && length $postsignin) {
+ $session->param(postsignin => $postsignin);
+ }
+
+ $session->param(name => $email);
+ my $nickname=$email;
+ $nickname=~s/@.*//;
+ $session->param(nickname => Encode::decode_utf8($nickname));
+
+ IkiWiki::cgi_savesession($session);
+
+ return $session;
+}
+
sub cleartoken ($) {
my $email=shift;
IkiWiki::userinfo_set($email, "emailauthexpire", 0);