/[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 351 by dpavlin, Sun Nov 16 13:01:56 2008 UTC revision 592 by dpavlin, Fri Nov 28 16:44:16 2008 UTC
# Line 1  Line 1 
1  package Frey::Run;  package Frey::Run;
2  use Moose;  use Moose;
3  #extends 'Frey::ClassLoader';  #extends 'Frey::ClassLoader';
4  extends 'Frey::PPI';  extends 'Frey::Action';
5  with 'Frey::Web';  with 'Frey::Session';
 with 'Frey::Config';  
 with 'Frey::Escape';  
6    
7  use Data::Dump qw/dump/;  use Data::Dump qw/dump/;
8  use Frey::Dumper;  use Frey::View::Dumper;
9    use JSON;
10    use YAML;
11    
12  =head1 NAME  =head1 NAME
13    
# Line 18  Frey::Run - display required form field Line 18  Frey::Run - display required form field
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>, and 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  use Moose::Util::TypeConstraints;  use Moose::Util::TypeConstraints;
28    
29  enum 'Runnable' => qw/data markup sponge/;  subtype 'Runnable'
30            => as 'Str',
31            => where sub { m{^as_} || m{_as_} };
32    
33  sub runnable { qw/data markup sponge/ }  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 41  has 'params' => ( Line 48  has 'params' => (
48  has 'run' => (  has 'run' => (
49          is => 'rw',          is => 'rw',
50          isa => 'Runnable',          isa => 'Runnable',
51          default => 'markup',          default => 'as_markup',
52    );
53    
54    has 'format' => (
55            is => 'rw',
56            isa => 'Formats',
57            default => 'html',
58  );  );
59    
60  sub html {  sub html {
61          my ( $self ) = @_;          my ( $self ) = @_;
62    
63          my $class = $self->class;          my ($html,$body,$data);
64            eval {
65                    my $class = $self->class;
66                    $self->load_class( $class );
67    
68                    if ( my $form = $self->params_form ) {
69                            $html = $self->page( body => $form );
70                            warn "got required params form for $class ", $self->run, " format: ", $self->format;
71                    } else {
72    
73          $self->load_class( $class );                          $self->usage->{ $class }++;
74    
75          my @required =  =begin remove
                 grep {  
                         defined $_ && $_->can('name') && !defined( $self->params->{ $_->name } )  
                 }  
                 map {  
                         my $attr = $class->meta->get_attribute($_);  
                         $attr->is_required && $attr;  
                 } $class->meta->get_attribute_list;  
   
         warn "## required = ",dump( map { $_->name } @required ), " for $class";  
   
         my $html;  
         my $values = {};  
         $values = $self->config($class);  
         warn "# $class config = ",dump( $values );  
   
         if ( @required ) {  
                 $html = qq|<h1>$class params</h1><form method="post">|;  
   
                 my $a;  
                 my @attrs = map {  $a->{$_}++; $_ } $self->attribute_order;  
                 push @attrs, $_ foreach grep { ! $a->{$_} } map { $_->name } @required;  
                 warn "# attrs = ",dump( @attrs );  
   
                 foreach my $name ( @attrs ) {  
                         my $attr = $class->meta->get_attribute( $name );  
                         my $type = $name =~ m/^pass/ ? 'password' : 'text';  
                         my $value = '';  
                         my $value_html = '';  
                         if ( ref($values) eq 'HASH' ) {  
                                 $value = $values->{$name};  
                         } elsif ( ref($values) eq 'ARRAY' ) {  
                                 $value_html = qq|<select name="$name">| . join("\n",  
                                         map {  
                                                 my $v = $_->{$name};  
                                                 qq|<option value="$v">$v</option>|  
                                         } @$values  
                                 ) . qq|</select>|;  
                         } elsif ( $attr->has_type_constraint && $attr->type_constraint->can('values') ) {  
                                 $value_html = qq|<select name="$name">| . join("\n",  
                                         map { qq|<option value="$_">$_</option>| } @{ $attr->type_constraint->values }  
                                 ) . qq|</select>|;  
                         } elsif ( $attr->has_default ) {  
                                 $value = $attr->default( $name );  
                         }  
                         $value_html = qq|<input type="$type" name="$name" value="$value">| unless $value_html;  
76    
77  #warn "# required $name ", $class->meta->get_attribute( $name )->dump( 2 );                          my $o;
78                          $html .= qq|<label for="$name">$name</label>| . $value_html;                          my ( $meta, $is_role, $instance ) = $self->class_meta( $class );
79                  }                          if ( $is_role ) {
80                  $html .= qq|<input type="submit" value="Run $class"></form>|;                                  $o = $instance;
81          } else {                                  if ( $o->can('add_status') ) {
82                  my $o;                                          $self->TODO("missing add_status in $o");
83                  eval { $o = $class->new( %{ $self->params } ); };                                          Frey::Web->meta->apply( $o );
84                  if ( $@ ) {                                          warn "# apply Frey::Web to $class instance $o";
85                          return $self->page( title => $class, body => $self->error( $@ ) );                                  }
                 }  
                 $o->depends if $o->can('depends');  
   
                 if ( $self->run eq 'markup' ) {  
                         warn "## using ",ref($o), "->markup";  
                         $html = eval { $o->markup };  
                         $html .= $self->error( $@ ) if $@;  
                         warn ">>> markup $class ",length( $html ), " bytes\n";  
                 } elsif ( $self->run eq 'sponge' ) {  
                         my $data = eval { $o->sponge };  
                         if ( $@ ) {  
                                 $html .= $self->error( $@ );  
86                          } else {                          } else {
87                                  $html .= '<table>';                                  $o = $self->new_frey_class( $class, $self->params );
                                 $html .= '<tr><th>' . join('</th><th>', @{$data->{NAME}} ) . '</th></tr>';  
                                 $html .= '<tr><td>' . join('</td><td>', @$_ ) . '</td></tr>' foreach @{ $data->{rows} };  
                                 $html .= '</table>';  
88                          }                          }
89                  } elsif ( $self->run eq 'data' ) {  =cut
90                          my $data = eval { $o->data; };  
91                          if ( $@ ) {                          my $o = $self->new_frey_class( $class, $self->params );
92                                  $html .= $self->error( $@ );                          $o->depends if $o->can('depends');
93    
94                            if ( $self->run =~ m{as_markup} ) {
95                                    $html = $o->page( run => $self->run );
96                            } elsif ( $self->run =~ m{as_sponge} ) {
97                                    $data = $o->as_sponge;
98                                    confess "invalid data from sponge = ", dump( $data ) unless ref($data) eq 'HASH';
99                                    if ( $self->format eq 'html' ) {
100                                            my $rows = $#{ $data->{rows} } + 1;
101                                            $rows ||= 'no';
102                                            $body .= "<strong>$rows</strong> rows from <code>$class->new" . dump( $self->params ) . "->as_sponge</code>";
103                                            $body .= '<table>';
104                                            $body .= '<tr><th>' . join('</th><th>', @{$data->{NAME}} ) . '</th></tr>';
105                                            $body .= '<tr><td>' . join('</td><td>', @$_ ) . '</td></tr>' foreach @{ $data->{rows} };
106                                            $body .= '</table>';
107                                    }
108                            } elsif ( $self->run =~ m{as_data} ) {
109                                    $data = $o->{$self->run}();
110                                    warn "no data from ", $self->run;
111                                    $data ||= $o->as_data();
112                                    confess "no data for $class->" . $self->run . " from " . $self->html_dump( $data ) unless $data;
113                                    $self->add_status( { $self->run => $data } );
114                          } else {                          } else {
115                                  $html .= Frey::Dumper->new( data => $data )->markup;                                  $body = $self->error( "IGNORE: $class ", $o->dump );
                                 $html .= '<hr/><code>' . $self->html_dump( $data ) . '</code>';  
116                          }                          }
117                  } else {  
118                          $html = $self->error( "IGNORE: $class ", $o->dump );                          if ( defined $data ) {
119                  }                                  $html .= to_json( $data ) if $self->format =~ m{js(on)?};
120                                    $html .= Dump( $data )    if $self->format =~ m{ya?ml};
121                            }
122                            if ( ! $html ) {
123                                    $body  = Frey::View::Dumper->new( data => $body )->as_markup if ref $body;
124                                    $body .= Frey::View::Dumper->new( data => $data )->as_markup if defined $data;
125                            }
126    
127                            $self->title( $class );
128    
129                            $html = $o->page( body => $body ) if $body && !$html;
130            
131                            confess "no html output for $class ", $o->dump unless defined $html;
132                    };
133    
134            };
135    
136            $self->status_parts;
137    
138            if ( $@ ) {
139                    my $o = Frey->new;
140                    Frey::Web->meta->apply( $o );
141                    $html = $o->page( body => $self->error( $@ ) );
142          }          }
143    
144          return $self->page( title => $class, body => $html );          warn $self->class, " produced ", length($html), " bytes";
145    
146            return $html;
147  }  }
148    
149  1;  1;

Legend:
Removed from v.351  
changed lines
  Added in v.592

  ViewVC Help
Powered by ViewVC 1.1.26