X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FView%2FComponent%2FSubInclude%2FESI.pm;h=2393c2c9c683c10377a652dcdce843541b1afc45;hb=1113d995f95905c6bd3fec5987c816a21de6657a;hp=f2b499aba4384d983ef3c6434b271ac6fdce2f61;hpb=62ebc3f489a670f528b4d3e375cddb88729816cc;p=catagits%2FCatalyst-View-Component-SubInclude.git
diff --git a/lib/Catalyst/View/Component/SubInclude/ESI.pm b/lib/Catalyst/View/Component/SubInclude/ESI.pm
index f2b499a..2393c2c 100644
--- a/lib/Catalyst/View/Component/SubInclude/ESI.pm
+++ b/lib/Catalyst/View/Component/SubInclude/ESI.pm
@@ -8,11 +8,11 @@ Catalyst::View::Component::SubInclude::ESI - Edge Side Includes (ESI) plugin for
=head1 VERSION
-Version 0.01
+Version 0.04
=cut
-our $VERSION = '0.01';
+our $VERSION = '0.04';
=head1 SYNOPSIS
@@ -37,14 +37,16 @@ Edge Side Includes (ESI) include directives. This is a feature implemented by
Varnish (L) which allows cache-efficient
uses of includes.
-=head1 STASH FUNCTION
+=head1 CLASS METHODS
-=head2 C
+=head2 C
-This will roughly translate to the following code:
+Note that C<$path> should be the private action path - translation to the public
+path is handled internally. After translation, this will roughly translate to
+the following code:
- my $url = $c->uri_for( @args );
-
+ my $url = $c->uri_for( $translated_path, @args )->path_query;
+ return '';
Notice that the stash will always be empty. This behavior could be configurable
in the future through an additional switch - for now, this behavior guarantees a
@@ -53,10 +55,16 @@ common interface for plugins.
=cut
sub generate_subinclude {
- my $class = shift;
- my $c = shift;
- my $url = $c->uri_for( @_ );
- return '';
+ my ($class, $c, $path, @params) = @_;
+
+ my $args = ref $params[0] eq 'ARRAY' ? shift @params : [];
+
+ my $dispatcher = $c->dispatcher;
+ my ($action) = $dispatcher->_invoke_as_path( $c, $path, $args );
+
+ my $uri = $c->uri_for( $action, $args, @params );
+
+ return '';
}
=head1 SEE ALSO