add alt. hook to PerRequestSchema trait
Brendan Byrd [Fri, 6 Apr 2012 20:41:15 +0000 (16:41 -0400)]
Allow defining the per_request_schema hook in the PerRequestSchema trait
and document it.

Changes
lib/Catalyst/Model/DBIC/Schema.pm
lib/Catalyst/TraitFor/Model/DBIC/Schema/PerRequestSchema.pm

diff --git a/Changes b/Changes
index e4f34fb..9ccf8ba 100644 (file)
--- a/Changes
+++ b/Changes
@@ -1,7 +1,8 @@
 Revision history for Perl extension Catalyst::Model::DBIC::Schema
 
-       - Additional paranoia in types as it's possible for loading code
-         to clobber $_
+        - Add per_request_schema hook to PerRequestSchema trait and docs
+        - Additional paranoia in types as it's possible for loading code
+          to clobber $_
 
 0.59  2011-11-01 11:20:46
         - update helper deps for new loader
index 822f443..a1f229e 100644 (file)
@@ -676,7 +676,7 @@ ozum: Ozum Eldogan C<ozum@ozum.net>
 
 Pavel I. Shaydo C<zwon@trinitum.org>
 
-t0m: Tomas Doran <bobtfish@bobtfish.net>
+SineSwiper: Brendan Byrd <byrd.b@insightcom.com>
 
 =head1 COPYRIGHT
 
index 337a3c1..71bad99 100644 (file)
@@ -1,9 +1,7 @@
 package Catalyst::TraitFor::Model::DBIC::Schema::PerRequestSchema;
 
 use Moose::Role;
-use namespace::autoclean;
-
-requires 'per_request_schema_attributes';
+use MooseX::MarkAsMethods autoclean => 1;
 
 with 'Catalyst::Component::InstancePerContext';
 
@@ -18,9 +16,16 @@ with attributes for each requests
         traits => ['PerRequestSchema'],
     });
 
-    method per_request_schema_attributes($c) {
+    sub per_request_schema_attributes {
+        my ($self, $c) = @_;
         return (restricting_object => $c->user->obj);
     }
+    ### OR ###
+    sub per_request_schema {
+        my ($self, $c) = @_;
+        return $self->schema->schema_method($c->user->obj)
+    }
+    
 
 =head1 DESCRIPTION
 
@@ -28,6 +33,10 @@ Clones the schema for each new request with the attributes retrieved from your
 C<per_request_schema_attributes> method, which you must implement. This method
 is passed the context.
 
+Alternatively, you could also override the C<per_request_schema> method if you
+need access to the schema clone and/or need to separate out the Model/Schema
+methods.  (See examples above and the defaults in the code.)
+
 =cut
 
 sub build_per_context_instance {
@@ -36,11 +45,23 @@ sub build_per_context_instance {
 
     my $new = bless {%$self}, ref $self;
 
-    $new->schema($new->schema->clone($self->per_request_schema_attributes($ctx)));
+    $new->schema($new->per_request_schema($ctx));
 
     return $new;
 }
 
+# Thanks to Matt Trout for this idea
+sub per_request_schema {
+    my ($self, $c) = @_;
+    return $self->schema->clone($self->per_request_schema_attributes($c));
+}
+
+### TODO: This should probably be more elegant ###
+sub per_request_schema_attributes {
+   confess "Either per_request_schema_attributes needs to be created, or per_request_schema needs to be overridden!";
+}
+
+
 =head1 SEE ALSO
 
 L<Catalyst::Model::DBIC::Schema>, L<DBIx::Class::Schema>