1 |
package Frey::Pipe; |
package Frey::Pipe; |
2 |
use Moose; |
use Moose; |
3 |
extends 'Frey'; |
extends 'Frey::ClassLoader'; |
4 |
|
with 'Frey::Web'; |
5 |
|
|
6 |
use Frey::Action; |
use Frey::Action; |
7 |
|
|
11 |
|
|
12 |
=head1 EXAMPLE |
=head1 EXAMPLE |
13 |
|
|
14 |
Frey::Feed/data + uri=http://blog.rot13.org/index.xml | Frey::Dumper/markup |
Frey::Feed/as_data + uri=http://blog.rot13.org/index.xml | Frey::View::Dumper/as_markup |
15 |
|
|
16 |
this will produce following code: |
this will produce following code: |
17 |
|
|
18 |
Frey::Dumper->new( data => |
Frey::View::Dumper->new( data => |
19 |
Frey::Feed->new( uri => 'http://blog.rot13.org/index.xml' )->data |
Frey::Feed->new( uri => 'http://blog.rot13.org/index.xml' )->as_data |
20 |
)->markup |
)->as_markup |
21 |
|
|
22 |
=cut |
=cut |
23 |
|
|
24 |
has pipe => ( |
has pipe => ( |
25 |
is => 'rw', |
is => 'rw', |
26 |
required => 1, |
required => 1, |
27 |
default => 'Frey::Feed/data+uri=http://blog.rot13.org/index.xml|Frey::Dumper/markup', |
default => 'Frey::Feed/as_data+uri=http://blog.rot13.org/index.xml|Frey::View::Dumper/as_markup', |
28 |
); |
); |
29 |
|
|
30 |
use Data::Dump qw/dump/; |
use Data::Dump qw/dump/; |
31 |
|
|
32 |
sub markup { |
sub as_markup { |
33 |
my ($self) = @_; |
my ($self) = @_; |
34 |
|
|
35 |
my $out; |
my $out; |
36 |
my $pipe; |
my $pipe; |
37 |
|
|
38 |
|
$self->title( $self->pipe ); |
39 |
|
|
40 |
|
my @parts; |
41 |
|
|
42 |
foreach my $part ( split(/\|/, $self->pipe ) ) { |
foreach my $part ( split(/\|/, $self->pipe ) ) { |
43 |
warn "# part: '$part'"; |
warn "# part: '$part'"; |
44 |
if ( $part =~ m{^([^/]+)/([^\+\?]+)(.*)?$} ) { |
if ( $part =~ m{^([^/]+)/([^\+\?]+)(.*)?$} ) { |
55 |
} |
} |
56 |
|
|
57 |
my ( $html, $default ) = Frey::Action->new( class => $class, params => $params )->params_form; |
my ( $html, $default ) = Frey::Action->new( class => $class, params => $params )->params_form; |
58 |
warn "$class need more params than ",dump( $default ) if $html; # FIXME replace with query |
warn "$class need more params than ",dump( $default ) if $html && $self->debug; # FIXME replace with query |
59 |
|
|
60 |
|
warn "# pipe $part" if $self->debug; |
61 |
|
my $o = $self->new_frey_class( $class, $default ); |
62 |
|
my $result = $o->$method; |
63 |
|
warn "# result ",length( $result ), " bytes ", ref($result); |
64 |
|
|
65 |
|
$self->add_status({ $part => { $class => { method => $method, args => $args } } }); |
66 |
|
|
67 |
|
$self->content_type( $o->content_type ) if $o->can('content_type'); |
68 |
|
|
|
my $code = '$result = ' . $class . '->new' . dump( %$default ) . '->' . $method . '();'; |
|
|
warn "# pipe $part -> $code"; |
|
|
my $result; |
|
|
eval $code; |
|
|
die $@ if $@; |
|
|
warn "# result ",ref( $result ); |
|
|
# $out .= qq{<span class="frey-popdown">$part<code>} . dump( $result ) . '</code><span><hr>'; |
|
69 |
$out = $result; |
$out = $result; |
70 |
|
$method =~ s{^as_}{}; |
71 |
$pipe = { $method => $result }; |
$pipe = { $method => $result }; |
72 |
} else { |
} else { |
73 |
die "don't know what to do with '$part' from ",$self->pipe; |
die "don't know what to do with '$part' from ",$self->pipe; |
74 |
} |
} |
75 |
} |
} |
76 |
|
|
77 |
return '<code>' . $self->pipe . '</code>' . $out; |
return $out; |
78 |
} |
} |
79 |
|
|
80 |
1; |
1; |