2006-03-23 07:51:15 +01:00
|
|
|
#!/usr/bin/perl
|
2008-07-10 04:47:06 +02:00
|
|
|
# Ikiwiki setup files are perl files that 'use IkiWiki::Setup::foo',
|
|
|
|
# passing it some sort of configuration data.
|
2006-03-23 07:51:15 +01:00
|
|
|
|
2008-07-10 04:39:26 +02:00
|
|
|
package IkiWiki::Setup;
|
2008-07-11 12:07:48 +02:00
|
|
|
|
2006-03-23 07:51:15 +01:00
|
|
|
use warnings;
|
|
|
|
use strict;
|
2006-05-02 08:53:33 +02:00
|
|
|
use IkiWiki;
|
2006-09-10 20:16:43 +02:00
|
|
|
use open qw{:utf8 :std};
|
2008-08-06 02:11:23 +02:00
|
|
|
use File::Spec;
|
2006-03-23 07:51:15 +01:00
|
|
|
|
2008-07-10 04:39:26 +02:00
|
|
|
sub load ($) { # {{{
|
|
|
|
my $setup=IkiWiki::possibly_foolish_untaint(shift);
|
2008-08-06 07:58:04 +02:00
|
|
|
$config{setupfile}=File::Spec->rel2abs($setup);
|
|
|
|
|
2007-01-04 13:00:23 +01:00
|
|
|
#translators: The first parameter is a filename, and the second
|
|
|
|
#translators: is a (probably not translated) error message.
|
2006-12-29 05:38:40 +01:00
|
|
|
open (IN, $setup) || error(sprintf(gettext("cannot read %s: %s"), $setup, $!));
|
2006-03-24 03:42:19 +01:00
|
|
|
my $code;
|
|
|
|
{
|
|
|
|
local $/=undef;
|
|
|
|
$code=<IN>;
|
|
|
|
}
|
2006-03-23 07:51:15 +01:00
|
|
|
($code)=$code=~/(.*)/s;
|
|
|
|
close IN;
|
|
|
|
|
|
|
|
eval $code;
|
2007-11-17 20:06:11 +01:00
|
|
|
error("$setup: ".$@) if $@;
|
2008-07-27 21:08:10 +02:00
|
|
|
} #}}}
|
2006-03-26 07:08:41 +02:00
|
|
|
|
2008-07-27 21:08:10 +02:00
|
|
|
sub merge ($) {
|
2008-08-02 19:38:45 +02:00
|
|
|
# Merge setup into existing config and untaint.
|
2008-07-27 21:08:10 +02:00
|
|
|
my %setup=%{shift()};
|
2008-07-10 04:39:26 +02:00
|
|
|
|
2008-09-01 04:11:59 +02:00
|
|
|
if (exists $setup{add_plugins} && exists $config{add_plugins}) {
|
2008-07-26 21:34:38 +02:00
|
|
|
push @{$setup{add_plugins}}, @{$config{add_plugins}};
|
2008-07-10 04:39:26 +02:00
|
|
|
}
|
|
|
|
if (exists $setup{exclude}) {
|
|
|
|
push @{$config{wiki_file_prune_regexps}}, $setup{exclude};
|
|
|
|
}
|
|
|
|
foreach my $c (keys %setup) {
|
|
|
|
if (defined $setup{$c}) {
|
2008-07-26 21:34:38 +02:00
|
|
|
if (! ref $setup{$c} || ref $setup{$c} eq 'Regexp') {
|
2008-07-26 18:46:31 +02:00
|
|
|
$config{$c}=IkiWiki::possibly_foolish_untaint($setup{$c});
|
2008-07-10 04:39:26 +02:00
|
|
|
}
|
|
|
|
elsif (ref $setup{$c} eq 'ARRAY') {
|
2008-07-27 03:00:11 +02:00
|
|
|
if ($c eq 'wrappers') {
|
|
|
|
# backwards compatability code
|
|
|
|
$config{$c}=$setup{$c};
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$config{$c}=[map { IkiWiki::possibly_foolish_untaint($_) } @{$setup{$c}}]
|
|
|
|
}
|
2008-07-10 04:39:26 +02:00
|
|
|
}
|
|
|
|
elsif (ref $setup{$c} eq 'HASH') {
|
|
|
|
foreach my $key (keys %{$setup{$c}}) {
|
2008-07-26 18:46:31 +02:00
|
|
|
$config{$c}{$key}=IkiWiki::possibly_foolish_untaint($setup{$c}{$key});
|
2008-07-10 04:39:26 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$config{$c}=undef;
|
|
|
|
}
|
|
|
|
}
|
2008-07-27 03:00:11 +02:00
|
|
|
|
2008-07-27 03:14:07 +02:00
|
|
|
if (length $config{cgi_wrapper}) {
|
2008-07-27 03:00:11 +02:00
|
|
|
push @{$config{wrappers}}, {
|
|
|
|
cgi => 1,
|
|
|
|
wrapper => $config{cgi_wrapper},
|
|
|
|
wrappermode => (defined $config{cgi_wrappermode} ? $config{cgi_wrappermode} : "06755"),
|
|
|
|
};
|
|
|
|
}
|
2006-03-23 07:51:15 +01:00
|
|
|
} #}}}
|
|
|
|
|
2008-08-02 19:38:45 +02:00
|
|
|
sub getsetup () { #{{{
|
2008-08-03 22:23:41 +02:00
|
|
|
# Gets all available setup data from all plugins. Returns an
|
|
|
|
# ordered list of [plugin, setup] pairs.
|
2008-08-02 19:38:45 +02:00
|
|
|
my @ret;
|
|
|
|
|
2008-08-03 22:23:41 +02:00
|
|
|
# disable logging to syslog while dumping, broken plugins may
|
|
|
|
# whine when loaded
|
2008-08-03 04:22:53 +02:00
|
|
|
my $syslog=$config{syslog};
|
2008-08-06 01:36:53 +02:00
|
|
|
$config{syslog}=undef;
|
2008-08-03 04:22:53 +02:00
|
|
|
|
2008-08-02 19:38:45 +02:00
|
|
|
# Load all plugins, so that all setup options are available.
|
2008-08-02 22:53:20 +02:00
|
|
|
my @plugins=grep { $_ ne $config{rcs} } sort(IkiWiki::listplugins());
|
2008-08-02 19:38:45 +02:00
|
|
|
unshift @plugins, $config{rcs} if $config{rcs}; # rcs plugin 1st
|
|
|
|
foreach my $plugin (@plugins) {
|
|
|
|
eval { IkiWiki::loadplugin($plugin) };
|
|
|
|
if (exists $IkiWiki::hooks{checkconfig}{$plugin}{call}) {
|
|
|
|
my @s=eval { $IkiWiki::hooks{checkconfig}{$plugin}{call}->() };
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
foreach my $plugin (@plugins) {
|
|
|
|
if (exists $IkiWiki::hooks{getsetup}{$plugin}{call}) {
|
|
|
|
# use an array rather than a hash, to preserve order
|
|
|
|
my @s=eval { $IkiWiki::hooks{getsetup}{$plugin}{call}->() };
|
|
|
|
next unless @s;
|
|
|
|
push @ret, [ $plugin, \@s ],
|
|
|
|
}
|
|
|
|
}
|
2008-08-03 04:22:53 +02:00
|
|
|
|
|
|
|
$config{syslog}=$syslog;
|
2008-08-02 19:38:45 +02:00
|
|
|
|
|
|
|
return @ret;
|
|
|
|
} #}}}
|
|
|
|
|
2008-07-26 21:39:41 +02:00
|
|
|
sub dump ($) { #{{{
|
|
|
|
my $file=IkiWiki::possibly_foolish_untaint(shift);
|
|
|
|
|
|
|
|
require IkiWiki::Setup::Standard;
|
2008-07-26 21:43:25 +02:00
|
|
|
my @dump=IkiWiki::Setup::Standard::gendump("Setup file for ikiwiki.");
|
2008-07-26 21:39:41 +02:00
|
|
|
|
|
|
|
open (OUT, ">", $file) || die "$file: $!";
|
2008-07-26 21:43:25 +02:00
|
|
|
print OUT "$_\n" foreach @dump;
|
2008-07-26 21:39:41 +02:00
|
|
|
close OUT;
|
|
|
|
}
|
|
|
|
|
2006-03-23 07:51:15 +01:00
|
|
|
1
|