diff options
author | Amitai Schlair <schmonz@magnetic-babysitter.(none)> | 2009-09-10 17:34:52 -0400 |
---|---|---|
committer | Amitai Schlair <schmonz@magnetic-babysitter.(none)> | 2009-09-10 17:34:52 -0400 |
commit | b2bd2e93f01979df1a25e6f349022103bc20339a (patch) | |
tree | e05cd6dd41e825dfd541911499aa56fd91800c00 /IkiWiki/Plugin/rsync.pm | |
parent | 06c712a7f0c75da344da43cd6030924b856a9439 (diff) | |
download | ikiwiki-b2bd2e93f01979df1a25e6f349022103bc20339a.tar ikiwiki-b2bd2e93f01979df1a25e6f349022103bc20339a.tar.gz |
Revivify unixauth and rsync plugins (and hook needed by rsync) lost in
the last merge. I should really put each feature on its own git branch.
Diffstat (limited to 'IkiWiki/Plugin/rsync.pm')
-rw-r--r-- | IkiWiki/Plugin/rsync.pm | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/IkiWiki/Plugin/rsync.pm b/IkiWiki/Plugin/rsync.pm new file mode 100644 index 000000000..3f049457b --- /dev/null +++ b/IkiWiki/Plugin/rsync.pm @@ -0,0 +1,45 @@ +#!/usr/bin/perl +package IkiWiki::Plugin::rsync; + +use warnings; +use strict; +use IkiWiki 3.00; + +sub import { + hook(type => "getsetup", id => "rsync", call => \&getsetup); + hook(type => "checkconfig", id => "rsync", call => \&checkconfig); + hook(type => "postrefresh", id => "rsync", call => \&postrefresh); +} + +sub getsetup () { + return + plugin => { + safe => 0, + rebuild => 0, + }, + rsync_command => { + type => "string", + example => "rsync -qa --delete /path/to/destdir/ user\@host:/path/to/docroot/", + description => "unattended command to upload regenerated pages", + safe => 0, + rebuild => 0, + }, +} + +sub checkconfig { + if (! exists $config{rsync_command} || + ! defined $config{rsync_command}) { + error("Must specify rsync_command"); + } +} + +sub postrefresh () { + system $config{rsync_command}; + if ($? == -1) { + error("failed to execute rsync_command: $!"); + } elsif ($? != 0) { + error(sprintf("rsync_command exited %d", $? >> 8)); + } +} + +1 |