diff options
author | Joey Hess <joey@kodama.kitenet.net> | 2008-07-27 15:44:11 -0400 |
---|---|---|
committer | Joey Hess <joey@kodama.kitenet.net> | 2008-07-27 15:44:11 -0400 |
commit | 929a70a16d898051f37ee497f275a894d6fc1362 (patch) | |
tree | fa4fdde4785b379c2006ed23d5b2820b7e148e98 /IkiWiki/Setup | |
parent | c755bfd1d88f52a6b4b0e1eef6f2aae0da705fb7 (diff) |
password prompt for admin user
Diffstat (limited to 'IkiWiki/Setup')
-rw-r--r-- | IkiWiki/Setup/Automator.pm | 38 |
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! |