]> git.decadent.org.uk Git - maypole.git/commitdiff
"If you set a template in the authenticate method, then the model's action will not...
authorSimon Cozens <simon@simon-cozens.org>
Tue, 24 Feb 2004 14:55:23 +0000 (14:55 +0000)
committerSimon Cozens <simon@simon-cozens.org>
Tue, 24 Feb 2004 14:55:23 +0000 (14:55 +0000)
git-svn-id: http://svn.maypole.perl.org/Maypole/trunk@72 48953598-375a-da11-a14b-00016c27c3ee

lib/Maypole/Model/Base.pm

index d092e502dd33ae61866d3d43c80d7d32528cdcb1..30dacfe60015ad8227a4370fb1d5dff180c38242 100644 (file)
@@ -9,12 +9,15 @@ sub edit :Exported { }
 sub process {
     my ($class, $r) = @_;
     my $method = $r->action;
-    $r->{template} ||= $method; # Authentication may have done this for us
-    $r->objects([ $class->retrieve(shift @{$r->{args}}) ]);
-
-    # This allows the authentication mechanism to set the template
-    # without needing to define an action.
-    $class->$method($r) if $class->can($method);
+    return if $r->{template}; # Authentication has set this, we're done.
+
+    $r->{template} = $method;
+    my $obj = $class->retrieve( $r->{args}->[0] );
+    if ($obj) {
+        $r->objects([ $obj ]);
+        shift @{$r->{args}};
+    }
+    $class->$method($r);
 }
 
 sub display_columns {