| Catalyst-View-Component-SubInclude documentation | view source | Contained in the Catalyst-View-Component-SubInclude distribution. |
Catalyst::View::Component::SubInclude::HTTP - HTTP plugin for C::V::Component::SubInclude
In your view class:
package MyApp::View::TT;
use Moose;
extends 'Catalyst::View::TT';
with 'Catalyst::View::Component::SubInclude';
__PACKAGE__->config(
subinclude_plugin => 'HTTP::GET',
subinclude => {
'HTTP::GET' => {
class => 'HTTP',
http_method => 'GET',
ua_timeout => '10',
uri_map => {
'/my/' => 'http://localhost:5000/',
},
},
'HTTP::POST' => {
class => 'HTTP',
http_method => 'POST',
ua_timeout => '10',
uri_map => {
'/foo/' => 'http://www.foo.com/',
},
},
},
);
Then, somewhere in your templates:
[% subinclude('/my/widget') %]
...
[% subinclude_using('HTTP::POST', '/foo/path', { foo => 1 }) %]
Catalyst::View::Component::SubInclude::HTTP does HTTP requests (currently
using LWP::UserAgent) and uses the responses to render subinclude contents.
The configuration is passed in the subinclude key based on your plugin name
which can be arbitrary.
Required just in case your plugin name differs from HTTP.
Accepts GET and POST as values. The default one is GET.
This lazily builds a LWP::UserAgent obj, however you can pass a different user agent obj that implements the required API.
User Agent's timeout config param. Defaults to 10 seconds.
This expects a HashRef in order to map paths to different URLs.
Used only if uri_map is undef and defaults to $c->request->base.
generate_subinclude( $c, $path, $args )Note that $path should be the relative path.
Wallace Reis <wreis@cpan.org>
Development sponsored by Ionzero LLC http://www.ionzero.com/.
Copyright (c) 2010 Wallace Reis.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
| Catalyst-View-Component-SubInclude documentation | view source | Contained in the Catalyst-View-Component-SubInclude distribution. |