Codebase list libcatalyst-plugin-smarturi-perl / HEAD
HEAD

Tree @HEAD (Download .tar.gz)

NAME

    Catalyst::Plugin::SmartURI - Configurable URIs for Catalyst

SYNOPSIS

    In your lib/MyApp.pm, load the plugin and your other plugins, for
    example:

        use Catalyst qw/
            -Debug
            ConfigLoader
            Static::Simple
            Session
            Session::Store::Memcached
            Session::State::Cookie
            Authentication
            Authorization::Roles
            +CatalystX::SimpleLogin
            SmartURI
        /;

    In your .conf:

        <Plugin::SmartURI>
            disposition host-header   # application-wide
            uri_class   URI::SmartURI # by default
        </Plugin::SmartURI>

    Per request:

        $c->uri_disposition('absolute');

    Methods on URIs:

        <a href="[% c.uri_for('/foo').relative %]" ...

DESCRIPTION

    Configure whether $c->uri_for and $c->req->uri_with return absolute,
    hostless or relative URIs, or URIs based on the 'Host' header. Also
    allows configuring which URI class to use. Works on application-wide or
    per-request basis.

    This is useful in situations where you're for example, redirecting to a
    lighttpd from a firewall rule, instead of a real proxy, and you want
    your links and redirects to still work correctly.

    To use your own URI class, just subclass URI::SmartURI and set
    uri_class, or write a class that follows the same interface.

    This plugin installs a custom $c->request_class, however it does so in
    a way that won't break if you've already set $c->request_class
    yourself, ie. by using Catalyst::Action::REST (thanks mst!).

    There is a minor performance penalty in perls older than 5.10, due to
    Class::C3, but only at initialization time.

METHODS

 $c->uri_for

 $c->req->uri_with

    Returns a $c->uri_class object (URI::SmartURI by default) in the
    configured $c->uri_disposition.

 $c->req->uri

    Returns a $c->uri_class object. If the context hasn't been prepared
    yet, uses the configured value for uri_class.

    $c->req->uri->relative will be relative to $c->req->base.

 $c->req->referer

    Returns a $c->uri_class object for the referer (or configured uri_class
    if there's no context) with reference set to $c->req->uri if it comes
    from $c->req->base.

    In other words, if referer is your app, you can do
    $c->req->referer->relative and it will do the right thing.

CONFIGURATION

    In myapp.conf:

        <Plugin::SmartURI>
            disposition absolute
            uri_class   URI::SmartURI
        </Plugin::SmartURI>

    disposition

      One of 'absolute', 'hostless', 'relative' or 'host-header'. Defaults
      to 'absolute'.

      The special disposition 'host-header' uses the value of your 'Host:'
      header.

    uri_class

      The class to use for URIs, defaults to URI::SmartURI.

PER REQUEST

        package MyAPP::Controller::RSSFeed;
    
        ...
    
        sub begin : Private {
            my ($self, $c) = @_;
    
            $c->uri_class('Your::URI::Class::For::Request');
            $c->uri_disposition('absolute');
        }

    $c->uri_disposition('absolute'|'hostless'|'relative'|'host-header')

      Set URI disposition to use for the duration of the request.

    $c->uri_class($class)

      Set the URI class to use for $c->uri_for and $c->req->uri_with for
      the duration of the request.

EXTENDING

    $c->prepare_uri actually creates the URI, which you can override.

SEE ALSO

    URI::SmartURI, Catalyst, URI

AUTHOR

    Rafael Kitover, <rkitover at cpan.org>

BUGS

    Please report any bugs or feature requests to
    bug-catalyst-plugin-smarturi at rt.cpan.org, or through the web
    interface at
    http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Catalyst-Plugin-SmartURI.
    I will be notified, and then you'll automatically be notified of
    progress on your bug as I make changes.

SUPPORT

    You can find documentation for this module with the perldoc command.

        perldoc Catalyst::Plugin::SmartURI

    You can also look for information at:

      * RT: CPAN's request tracker

      http://rt.cpan.org/NoAuth/Bugs.html?Dist=Catalyst-Plugin-SmartURI

      * AnnoCPAN: Annotated CPAN documentation

      http://annocpan.org/dist/Catalyst-Plugin-SmartURI

      * CPAN Ratings

      http://cpanratings.perl.org/d/Catalyst-Plugin-SmartURI

      * Search CPAN

      http://search.cpan.org/dist/Catalyst-Plugin-SmartURI

ACKNOWLEDGEMENTS

    from #catalyst:

    vipul came up with the idea

    mst came up with the design and implementation details for the current
    version

    kd reviewed my code and offered suggestions

TODO

    I'd like to extend on Catalyst::Plugin::RequireSSL, and make a plugin
    that rewrites URIs for actions with an SSL attribute.

COPYRIGHT & LICENSE

    Copyright (c) 2008 Rafael Kitover

    This program is free software; you can redistribute it and/or modify it
    under the same terms as Perl itself.