NAME

Rex::Transaction - Transaction support

DESCRIPTION

With this module you can define transactions and rollback scenarios on failure.

SYNOPSIS

 use Rex::Transaction;

 task 'do-something', 'server01', sub {
   transaction {
     on_rollback {
       rmdir '/tmp/mydata';
     };

     mkdir '/tmp/mydata';
     upload 'files/myapp.tar.gz', '/tmp/mydata';
     run 'tar xzf myapp.tar.gz -C /tmp/mydata';
     if ( $? != 0 ) { die('Error extracting myapp.tar.gz'); }
   };
 };

EXPORTED FUNCTIONS

transaction($codeRef)

Start a transaction for $codeRef. If $codeRef dies, Rex will run the on_rollback code to roll back the transaction.

 task 'deploy', group => 'frontend', sub {
   on_rollback {
     rmdir '...';
   };

   deploy 'myapp.tar.gz';
 };

 task 'restart_server', group => 'frontend', sub {
   service apache2 => 'restart';
 };

 task 'all', group => 'frontend', sub {
   transaction {
     do_task [qw/deploy restart_server/];
   };
 };

on_rollback($codeRef)

This will execute $codeRef if a step in the transaction fails.