/[Frey]/trunk/lib/Frey/Run.pm
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /trunk/lib/Frey/Run.pm

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 223 by dpavlin, Sat Nov 1 00:14:05 2008 UTC revision 581 by dpavlin, Fri Nov 28 13:16:47 2008 UTC
# Line 1  Line 1 
1  package Frey::Run;  package Frey::Run;
2  use Moose;  use Moose;
3  extends 'Frey';  #extends 'Frey::ClassLoader';
4  with 'Frey::Web';  extends 'Frey::Action';
5  with 'Frey::Config';  with 'Frey::Session';
6    
7    use Data::Dump qw/dump/;
8    use Frey::View::Dumper;
9    use JSON;
10    use YAML;
11    
12  =head1 NAME  =head1 NAME
13    
# Line 11  Frey::Run - display required form field Line 16  Frey::Run - display required form field
16  =head1 DESCRIPTION  =head1 DESCRIPTION
17    
18  This object will try to run other Moose objects from your application. It  This object will try to run other Moose objects from your application. It
19  will try to invoke C<data>, C<html> or C<markup> method on the.  will try to invoke C<data>, and C<markup> method on the.
20    
21    =head1 SEE ALSO
22    
23    L<Frey::Action> which creates form for params
24    
25  =cut  =cut
26    
27  sub execute { qw/data markup request/ }  use Moose::Util::TypeConstraints;
28    
29    subtype 'Runnable'
30            => as 'Str',
31            => where sub { m{^as_} || m{_as_} };
32    
33    sub formats_available { qw/html js json yaml yml/ }
34    enum 'Formats' => formats_available;
35    
36  has 'class' => (  has 'class' => (
37          is => 'rw',          is => 'rw',
# Line 23  has 'class' => ( Line 39  has 'class' => (
39          required => 1,          required => 1,
40  );  );
41    
42  use Data::Dump qw/dump/;  has 'params' => (
43            is => 'rw',
44            isa => 'HashRef',
45            default => sub { {} },
46    );
47    
48  sub request {  has 'run' => (
49          my ( $self, $req ) = @_;          is => 'rw',
50            isa => 'Runnable',
51            default => 'as_markup',
52    );
53    
54          my %params = $req->params;  has 'format' => (
55          my $class = $self->class;          is => 'rw',
56            isa => 'Formats',
57            default => 'html',
58    );
59    
60          my @required =  sub html {
61                  grep {          my ( $self ) = @_;
62                          defined $_ && !defined( $params{$_} )  
63                  }          my ($html,$body,$data);
64                  map {          eval {
65                          my $attr = $class->meta->get_attribute($_);                  my $class = $self->class;
66                          $attr->is_required && $_                  $self->load_class( $class );
67                  } $class->meta->get_attribute_list;  
68                    if ( $self->params_form ) {
69                  warn "## required = ",dump( @required );                          $html = $self->page;
70                  warn "## params = ",dump( %params );                          warn "got required params form for $class ", $self->run, " format: ", $self->format;
   
         my $html;  
   
         if ( @required ) {  
                 $html = qq|<h1>Required params for $class</h1><form method="post">|;  
                 foreach my $name ( @required ) {  
                         my $type = $name =~ m/^pass/ ? 'password' : 'text';  
                         my $value = $self->config($class)->{$name};  
                         $html .= qq|<label for="$name">$name</label><input type="$type" name="$name" value="$value">|;  
                 }  
                 $html .= qq|<input type="submit" value="Run $class"></form>|;  
         } else {  
                 my $o = $class->new( %params );  
                 $o->depends if $o->can('depends');  
                 if ( $o->can('request') ) {  
                         warn "## turning over to $o->request";  
                         $o->request( $req );  
                 } elsif ( $o->can('markup') ) {  
                         warn "## using $o->markup";  
                         $html = $o->markup;  
                         warn ">>> markup $class ",length( $html ), " bytes\n";  
                 } elsif ( $o->can('data') ) {  
                         $html = '<code>' . dump( $o->data ) . '</code>';  
71                  } else {                  } else {
                         $html = "IGNORE: $class ", $o->dump;  
                         warn $html;  
                 }  
         }  
72    
73          $req->print( $self->page( title => $class, body => $html ) );                          $self->usage->{ $class }++;
74    
75                            my $o;
76                            my ( $meta, $is_role, $instance ) = $self->class_meta( $class );
77                            if ( $is_role ) {
78                                    $o = $instance;
79                            } else {
80                                    $o = $self->new_frey_class( $class, $self->params );
81                            }
82    
83                            $o->depends if $o->can('depends');
84    
85                            $o->add_status( { $self->editor( $class ) => $self->params } );
86    
87                            if ( $self->run =~ m{as_markup} ) {
88                                    $html = $o->page;
89                            } elsif ( $self->run =~ m{as_sponge} ) {
90                                    $data = $o->as_sponge;
91                                    confess "invalid data from sponge = ", dump( $data ) unless ref($data) eq 'HASH';
92                                    if ( $self->format eq 'html' ) {
93                                            my $rows = $#{ $data->{rows} } + 1;
94                                            $rows ||= 'no';
95                                            $body .= "<strong>$rows</strong> rows from <code>$class->new" . dump( $self->params ) . "->as_sponge</code>";
96                                            $body .= '<table>';
97                                            $body .= '<tr><th>' . join('</th><th>', @{$data->{NAME}} ) . '</th></tr>';
98                                            $body .= '<tr><td>' . join('</td><td>', @$_ ) . '</td></tr>' foreach @{ $data->{rows} };
99                                            $body .= '</table>';
100                                    }
101                            } elsif ( $self->run =~ m{as_data} ) {
102                                    $data = $o->as_data;
103                            } else {
104                                    $body = $self->error( "IGNORE: $class ", $o->dump );
105                            }
106    
107                            if ( defined $data ) {
108                                    $html .= to_json( $data ) if $self->format =~ m{js(on)?};
109                                    $html .= Dump( $data )    if $self->format =~ m{ya?ml};
110                                    $self->add_status( { 'data' => $data } );
111                            }
112                            if ( ! $html ) {
113                                    $body  = Frey::View::Dumper->new( data => $body )->as_markup if ref $body;
114                                    $body .= Frey::View::Dumper->new( data => $data )->as_markup if defined $data;
115                            }
116    
117                            $self->title( $class );
118    
119                            $html = $o->page( body => $body ) if $body && !$html;
120                    };
121    
122            };
123    
124            $self->status_parts;
125    
126            $html = $self->error( $@ ) if $@;
127    
128            warn $self->class, " produced ", length($html), " bytes";
129    
130            return $html;
131  }  }
132    
133  1;  1;

Legend:
Removed from v.223  
changed lines
  Added in v.581

  ViewVC Help
Powered by ViewVC 1.1.26