Maypole::Plugin::Transaction - Transaction handling for Maypole


NAME

Maypole::Plugin::Transaction - Transaction handling for Maypole


SYNOPSIS

Simple transaction:

    package MyApp;
    use Maypole::Application qw(Transaction);
    # You should AutoCommit by default
    MyApp->setup( 'dbi:Pg:dbname=myapp', 'myuser', 'mypass',
        { AutoCommit => 1 } );
    sub do_something : Exported {
        my ( $self, $r ) = @_;
        my $h = CGI::Untaint->new( %{ $r->{params} } );
        warn 'Transaction failed!'
            unless $r->transaction( sub { $self->create_from_cgi($h) } );
    }

Advanced transaction with exception handling:

    package MyApp;
    use Maypole::Application qw(Transaction);
    use Maypole::Constants;
    use Exception::Class TransactionException =>
      { description => 'Transaction failed, so rolled back' };
    # You should AutoCommit by default
    MyApp->setup( 'dbi:Pg:dbname=myapp', 'myuser', 'mypass',
        { AutoCommit => 1 } );
    MyApp->config->transaction_exception('TransactionException');
    sub exception {
        my ( $r, $e ) = @_;
        if ( $e->isa('TransactionException') ) {
            warn "Transaction failed: $e";
            # Do something to correct the failure
            return OK;
        }
        return ERROR;
    }
    sub do_something : Exported {
        my ( $self, $r ) = @_;
        my $h = CGI::Untaint->new( %{ $r->{params} } );
        $r->transaction( sub { $self->create_from_cgi($h) } );
    }


DESCRIPTION

Commit, Rollback and throwing Exceptions!

Note that you need Maypole 2.0 or newer to use this module!

transaction

    my $status = $r->transaction( $coderef, $exception );

Returns true or false, the exception argument is optional.


AUTHOR

Sebastian Riedel, sri@oook.de


LICENSE

This library is free software. You can redistribute it and/or modify it under the same terms as perl itself.

 Maypole::Plugin::Transaction - Transaction handling for Maypole