package Fey::Object::Schema; BEGIN { $Fey::Object::Schema::VERSION = '0.43'; } use strict; use warnings; use namespace::autoclean; use Fey::Meta::Class::Table; use Moose; sub EnableObjectCaches { my $class = shift; $_->EnableObjectCache() for $class->_TableClasses(); } sub DisableObjectCaches { my $class = shift; $_->DisableObjectCache() for $class->_TableClasses(); } sub ClearObjectCaches { my $class = shift; $_->ClearObjectCache() for $class->_TableClasses(); } sub _TableClasses { my $class = shift; my $schema = $class->Schema(); return Fey::Meta::Class::Table->ClassForTable( $schema->tables() ); } sub RunInTransaction { my $class = shift; my $sub = shift; my $source = shift || $class->DBIManager()->default_source(); my $in_tran; my $dbh = $source->dbh(); unless ( $source->allows_nested_transactions() || $dbh->{AutoCommit} ) { $in_tran = 1; } my $wantarray = wantarray; my @r; eval { $dbh->begin_work() unless $in_tran; if ($wantarray) { @r = $sub->(); } elsif ( defined $wantarray ) { $r[0] = $sub->(); } else { $sub->(); } $dbh->commit() unless $in_tran; }; if ( my $e = $@ ) { $dbh->rollback unless $in_tran; die $e; } return unless defined $wantarray; return $wantarray ? @r : $r[0]; } sub Schema { my $class = shift; return $class->meta()->schema(); } sub DBIManager { my $class = shift; return $class->meta()->dbi_manager(); } sub SetDBIManager { my $class = shift; $class->meta()->set_dbi_manager(@_); } sub SQLFactoryClass { my $class = shift; return $class->meta()->sql_factory_class(); } sub SetSQLFactoryClass { my $class = shift; $class->meta()->set_sql_factory_class(@_); } __PACKAGE__->meta()->make_immutable( inline_constructor => 0 ); 1; # ABSTRACT: Base class for schema-based objects =pod =head1 NAME Fey::Object::Schema - Base class for schema-based objects =head1 VERSION version 0.43 =head1 SYNOPSIS package MyApp::Schema; use Fey::ORM::Schema; has_schema(...); =head1 DESCRIPTION This class is a the base class for all schema-based objects. =head1 METHODS This class provides the following methods: =head2 $class->EnableObjectCaches() Enables the object class for all of the table classes associated with this class's schema. =head2 $class->DisableObjectCaches() Disables the object class for all of the table classes associated with this class's schema. =head2 $class->ClearObjectCaches() Clears the object class for all of the table classes associated with this class's schema. =head2 $class->RunInTransaction( $coderef, $source ) Given a code ref, this method will begin a transaction and execute the coderef. If the coderef runs normally (no exceptions), it commits, otherwise it rolls back and rethrows the error. This method will handle nested transactions gracefully if your DBMS does not. It doesn't emulate actual partial commits, but it does prevent DBI from throwing an error. The second argument can be a L object. If no source is specified, then this method will use the default source. =head2 $class->Schema() Returns the L object associated with the class. =head2 $class->DBIManager() Returns the L object associated with the class. =head2 $class->SetDBIManager($manager) Set the L object associated with the class. If you don't set one explicitly, then the first call to C<< $class->DBIManager() >> will simply create one by calling C<< Fey::DBIManager->new() >>. =head2 $class->SQLFactoryClass() Returns the SQL factory class associated with the class. This defaults to L. =head2 $class->SetSQLFactoryClass() Set the SQL factory class associated with the class. =head1 AUTHOR Dave Rolsky =head1 COPYRIGHT AND LICENSE This software is copyright (c) 2011 by Dave Rolsky. This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself. =cut __END__