X-Git-Url: https://sipb.mit.edu/gitweb.cgi/ikiwiki.git/blobdiff_plain/7308f3da5bf2518f5a9659c7de6212ed5648f27b..85f4b99710fa94b9b67cee061c37eaf49be36b25:/ikiwiki.in diff --git a/ikiwiki.in b/ikiwiki.in index 4f24cfc2e..d601d2739 100755 --- a/ikiwiki.in +++ b/ikiwiki.in @@ -118,6 +118,17 @@ sub getconfig () { #{{{ error("WRAPPED_OPTIONS: $@"); } delete $ENV{WRAPPED_OPTIONS}; + + if ($config{post_commit} && ! commit_hook_enabled()) { + # optimisation for no-op post_commit + exit 0; + } + elsif ($config{test_receive}) { + # quick success if the user is trusted + require IkiWiki::Receive; + exit 0 if IkiWiki::Receive::trusted(); + } + loadplugins(); checkconfig(); } @@ -145,7 +156,8 @@ sub main () { #{{{ if exists $config{setupsyslog}; delete @config{qw(setupsyslog setupverbose wrappers genwrappers rebuild)}; checkconfig(); - if (! $config{cgi} && ! $config{post_commit}) { + if (! $config{cgi} && ! $config{post_commit} && + ! $config{test_receive}) { $config{post_commit}=1; } gen_wrapper(); @@ -183,6 +195,10 @@ sub main () { #{{{ elsif ($config{post_commit} && ! commit_hook_enabled()) { # do nothing } + elsif ($config{test_receive}) { + require IkiWiki::Receive; + IkiWiki::Receive::test(); + } else { if ($config{rebuild}) { debug(gettext("rebuilding wiki.."));