summaryrefslogtreecommitdiff
path: root/IkiWiki/Plugin/lockedit.pm
diff options
context:
space:
mode:
authorJoey Hess <joey@kodama.kitenet.net>2008-08-01 15:45:57 -0400
committerJoey Hess <joey@kodama.kitenet.net>2008-08-01 16:45:04 -0400
commitbb394fdae8ba488f1031d6f053f1544c689a3628 (patch)
tree760791186780419e0b0428435b00cdd25a481609 /IkiWiki/Plugin/lockedit.pm
parent4324746bea58784ad82a2de7832cafad2a25ed63 (diff)
admin prefs move to setup file, stage 1
The locked pages configuration is moving to a locked_pages option in the setup file, and the allowed attachments configuration to allowed_attachments. The admin prefs page can still be used for these, but that's depreacted and will only be shown if there's currently a value.
Diffstat (limited to 'IkiWiki/Plugin/lockedit.pm')
-rw-r--r--IkiWiki/Plugin/lockedit.pm48
1 files changed, 41 insertions, 7 deletions
diff --git a/IkiWiki/Plugin/lockedit.pm b/IkiWiki/Plugin/lockedit.pm
index 5ffb4e6f9..033b38263 100644
--- a/IkiWiki/Plugin/lockedit.pm
+++ b/IkiWiki/Plugin/lockedit.pm
@@ -6,11 +6,25 @@ use strict;
use IkiWiki 2.00;
sub import { #{{{
+ hook(type => "getsetup", id => "lockedit", call => \&getsetup);
hook(type => "canedit", id => "lockedit", call => \&canedit);
hook(type => "formbuilder_setup", id => "lockedit",
call => \&formbuilder_setup);
} # }}}
+sub getsetup () { #{{{
+ return
+ locked_pages => {
+ type => "string",
+ example => "!*/Discussion",
+ description => "PageSpec controlling which pages are locked",
+ description_html => htmllink("", "", "ikiwiki/PageSpec", noimageinline => 1).
+ " controlling which pages are locked",
+ safe => 1,
+ rebuild => 0,
+ },
+} #}}}
+
sub canedit ($$) { #{{{
my $page=shift;
my $cgi=shift;
@@ -19,6 +33,20 @@ sub canedit ($$) { #{{{
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})) {
+ if (! defined $user ||
+ ! IkiWiki::userinfo_get($session->param("name"), "regdate")) {
+ return sub { IkiWiki::needsignin($cgi, $session) };
+ }
+ else {
+ return sprintf(gettext("%s is locked and cannot be edited"),
+ htmllink("", "", $page, noimageinline => 1));
+
+ }
+ }
+
+ # XXX deprecated, should be removed eventually
foreach my $admin (@{$config{adminuser}}) {
if (pagespec_match($page, IkiWiki::userinfo_get($admin, "locked_pages"))) {
if (! defined $user ||
@@ -26,9 +54,8 @@ sub canedit ($$) { #{{{
return sub { IkiWiki::needsignin($cgi, $session) };
}
else {
- return sprintf(gettext("%s is locked by %s and cannot be edited"),
- htmllink("", "", $page, noimageinline => 1),
- IkiWiki::userlink($admin));
+ return sprintf(gettext("%s is locked and cannot be edited"),
+ htmllink("", "", $page, noimageinline => 1));
}
}
}
@@ -38,7 +65,8 @@ sub canedit ($$) { #{{{
sub formbuilder_setup (@) { #{{{
my %params=@_;
-
+
+ # XXX deprecated, should be removed eventually
my $form=$params{form};
if ($form->title eq "preferences") {
my $session=$params{session};
@@ -47,13 +75,19 @@ sub formbuilder_setup (@) { #{{{
$form->field(name => "locked_pages", size => 50,
fieldset => "admin",
- comment => "(".htmllink("", "", "ikiwiki/PageSpec", noimageinline => 1).")");
+ comment => "deprecated; please move to locked_pages in setup file"
+ );
if (! IkiWiki::is_admin($user_name)) {
$form->field(name => "locked_pages", type => "hidden");
}
if (! $form->submitted) {
- $form->field(name => "locked_pages", force => 1,
- value => IkiWiki::userinfo_get($user_name, "locked_pages"));
+ my $value=IkiWiki::userinfo_get($user_name, "locked_pages");
+ if (length $value) {
+ $form->field(name => "locked_pages", force => 1, value => $value);
+ }
+ else {
+ $form->field(name => "locked_pages", type => "hidden");
+ }
}
if ($form->submitted && $form->submitted eq 'Save Preferences') {
if (defined $form->field("locked_pages")) {