]> git.vanrenterghem.biz Git - git.ikiwiki.info.git/blobdiff - doc/plugins/lockedit/discussion.mdwn
refactor check_canchange into IkiWiki library
[git.ikiwiki.info.git] / doc / plugins / lockedit / discussion.mdwn
index b058b2b07f0e14dc19cdd4993db88938f8c2b6c0..867fc6a51010b4cf25b5ecf46c0bc0bccd94cf9c 100644 (file)
@@ -1,21 +1,18 @@
-This plugin not only locks pages but ensures too a user is logged in. This seems to me redundant with signedit. I propose :
+This plugin not only locks pages but ensures too a user is logged in. This
+seems to me redundant with signedit. I propose [removing the if block that
+calls needsignin ].
 
 
-    sub canedit ($$) {
-       my $page=shift;
-       my $cgi=shift;
-       my $session=shift;
-    
-       my $user=$session->param("name");
-       return undef if defined $user && IkiWiki::is_admin($user);
-    
-       if (defined $config{locked_pages} && length $config{locked_pages} &&
-           pagespec_match($page, $config{locked_pages},
-                   user => $session->param("name"),
-                   ip => $ENV{REMOTE_ADDR},
-           )) {
-               return sprintf(gettext("%s is locked and cannot be edited"),
-                       htmllink("", "", $page, noimageinline => 1));
-       }
-    
-       return undef;
-    }
+> That was added because the most typical reason for being unable to edit a
+> page is that you are not logged in. And without the jump to logging the
+> user in, there is no way for the user to log in, without navigating away
+> from the page they were trying to edit. --[[Joey]] 
+
+>> Ok, but the problem is that when you don't want any signin form you end up
+>> with a lone login button. That might happend if you lock pages only on IP
+>> adresses, if you use another cookie from another webapp...
+
+>> That happends to me and I had to reimplement lockedit in my private auth
+>> plugin.
+
+>> Perhaps you could return undef on that case and let another plugin do the
+>> needsignin call ? -- [[Jogo]]