X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=catagits%2FCatalyst-Runtime.git;a=blobdiff_plain;f=lib%2FCatalyst%2FDispatcher.pm;h=d3f25a3230ce0f219fb1d0eb2d7d82ef85772b42;hp=3ed32674253fc43576bc52bb85fb171eba410cb4;hb=6e3dd95f237370a2824e5ecc1419eaed075f0279;hpb=518b61984c49533ec00813125b16812cd681e778 diff --git a/lib/Catalyst/Dispatcher.pm b/lib/Catalyst/Dispatcher.pm index 3ed3267..d3f25a3 100644 --- a/lib/Catalyst/Dispatcher.pm +++ b/lib/Catalyst/Dispatcher.pm @@ -407,9 +407,14 @@ sub prepare_action { if ( $c->debug && @args ); } -=head2 $self->get_action( $action, $namespace ) +=head2 $self->get_action( $action_name, $namespace ) -returns a named action from a given namespace. +returns a named action from a given namespace. C<$action_name> +may be a relative path on that C<$namespace> such as + + $self->get_action('../bar', 'foo/baz'); + +In which case we look for the action at 'foo/bar'. =cut @@ -426,10 +431,15 @@ sub get_action { Returns the named action by its full private path. +This method performs some normalization on C<$path> so that if +it includes '..' it will do the right thing (for example if +C<$path> is '/foo/../bar' that is normalized to '/bar'. + =cut sub get_action_by_path { my ( $self, $path ) = @_; + $path =~s/[^\/]+\/\.\.\/// while $path=~m/\.\./; $path =~ s/^\///; $path = "/$path" unless $path =~ /\//; $self->_action_hash->{$path};