summaryrefslogtreecommitdiff
path: root/IkiWiki/Setup
diff options
context:
space:
mode:
authorJoey Hess <joey@kodama.kitenet.net>2008-07-27 15:44:11 -0400
committerJoey Hess <joey@kodama.kitenet.net>2008-07-27 15:44:11 -0400
commit929a70a16d898051f37ee497f275a894d6fc1362 (patch)
treefa4fdde4785b379c2006ed23d5b2820b7e148e98 /IkiWiki/Setup
parentc755bfd1d88f52a6b4b0e1eef6f2aae0da705fb7 (diff)
password prompt for admin user
Diffstat (limited to 'IkiWiki/Setup')
-rw-r--r--IkiWiki/Setup/Automator.pm38
1 files changed, 33 insertions, 5 deletions
diff --git a/IkiWiki/Setup/Automator.pm b/IkiWiki/Setup/Automator.pm
index af98c9847..202c5541c 100644
--- a/IkiWiki/Setup/Automator.pm
+++ b/IkiWiki/Setup/Automator.pm
@@ -6,6 +6,7 @@ package IkiWiki::Setup::Automator;
use warnings;
use strict;
use IkiWiki;
+use IkiWiki::UserInfo;
use Term::ReadLine;
use File::Path;
@@ -36,11 +37,11 @@ sub import (@) { #{{{
foreach my $key (qw{srcdir destdir repository dumpsetup}) {
next unless exists $config{$key};
my $add="";
- while (-e $config{$key}.$add) {
+ while (-e $add.$config{$key}) {
$add=1 if ! $add;
$add++;
}
- $config{$key}.=$add;
+ $config{$key}=$add.$config{$key};
}
IkiWiki::checkconfig();
@@ -76,10 +77,37 @@ sub import (@) { #{{{
}
IkiWiki::Setup::dump($config{dumpsetup});
- # Build the wiki.
+ # Build the wiki, but w/o wrappers, so it's not live yet.
mkpath($config{destdir}) || die "mkdir $config{destdir}: $!";
- if (system("ikiwiki", "--setup", $config{dumpsetup}) != 0) {
- die "ikiwiki --setup $config{dumpsetup} failed";
+ if (system("ikiwiki", "--refresh", "--setup", $config{dumpsetup}) != 0) {
+ die "ikiwiki --refresh --setup $config{dumpsetup} failed";
+ }
+
+ # Create admin user(s).
+ foreach my $admin (@{$config{adminuser}}) {
+ next if $admin=~/^http\?:\/\//; # openid
+
+ # Prompt for password w/o echo.
+ system('stty -echo 2>/dev/null');
+ local $|=1;
+ print "\n\nCreating wiki admin $admin ...\n";
+ print "Choose a password: ";
+ chomp(my $password=<STDIN>);
+ print "\n\n\n";
+ system('stty sane 2>/dev/null');
+
+ if (IkiWiki::userinfo_setall($admin, { regdate => time }) &&
+ IkiWiki::Plugin::passwordauth::setpassword($admin, $password)) {
+ IkiWiki::userinfo_set($admin, "email", $config{adminemail}) if defined $config{adminemail};
+ }
+ else {
+ error("problem setting up $admin user");
+ }
+ }
+
+ # Add wrappers, make live.
+ if (system("ikiwiki", "--wrappers", "--setup", $config{dumpsetup}) != 0) {
+ die "ikiwiki --wrappers --setup $config{dumpsetup} failed";
}
# Done!