/[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 336 by dpavlin, Sat Nov 8 23:03:35 2008 UTC revision 421 by dpavlin, Tue Nov 18 17:12:09 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::Web';
 with 'Frey::Config';  
6  with 'Frey::Escape';  with 'Frey::Escape';
7    
8  use Data::Dump qw/dump/;  use Data::Dump qw/dump/;
9  use Frey::Dumper;  use Frey::Dumper;
10    use JSON;
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  sub runnable { qw/data markup/ }  use Moose::Util::TypeConstraints;
28    
29    sub runnable { qw/data data.js markup sponge/ }
30    enum 'Runnable' => runnable;
31    
32    sub formats_available { qw/html js json yaml yml/ }
33    enum 'Formats' => formats_available;
34    
35  has 'class' => (  has 'class' => (
36          is => 'rw',          is => 'rw',
# Line 34  has 'params' => ( Line 44  has 'params' => (
44          default => sub { {} },          default => sub { {} },
45  );  );
46    
47    has 'run' => (
48            is => 'rw',
49            isa => 'Runnable',
50            default => 'markup',
51    );
52    
53    has 'format' => (
54            is => 'rw',
55            isa => 'Formats',
56            default => 'html',
57    );
58    
59  sub html {  sub html {
60          my ( $self ) = @_;          my ( $self ) = @_;
61    
62          my $class = $self->class;          my ($html,$body,$data);
63            eval {
64                    my $class = $self->class;
65                    $self->load_class( $class );
66    
67          $self->load_class( $class );                  if ( $body = $self->params_form ) {
68                            warn "got required params form for $class ", $self->run, " format: ", $self->format;
69                    } else {
70    
71          my @required =                          my $o = $class->new( %{ $self->params } );
72                  grep {                          $o->depends if $o->can('depends');
73                          defined $_ && $_->can('name') && !defined( $self->params->{ $_->name } )  
74                  }                          push @{ $self->status }, { qq|<a target="editor" href="/editor+$class+1">$class</a>| => $self->params };
75                  map {  
76                          my $attr = $class->meta->get_attribute($_);                          if ( $self->run eq 'markup' ) {
77                          $attr->is_required && $attr;                                  warn "## using ",ref($o), "->markup";
78                  } $class->meta->get_attribute_list;                                  if ( $o->can('page') ) {
79                                            $html = $o->page;
80          warn "## required = ",dump( map { $_->name } @required ), " for $class";                                          $body = $o->markup unless $html;
81                                    } else {
82          my $html;                                          $body = $o->markup;
83          my $values = {};                                  }
84          $values = $self->config($class);  
85          warn "# $class config = ",dump( $values );                                  warn ">>> markup $class ",length( $html || $body ), " ", $html ? 'html' : 'body', " bytes";
86                            } elsif ( $self->run eq 'sponge' ) {
87          if ( @required ) {                                  $data = $o->sponge;
88                  $html = qq|<h1>$class params</h1><form method="post">|;                                  confess "invalid data from sponge = ", dump( $data ) unless ref($data) eq 'HASH';
89                                    if ( $self->format eq 'html' ) {
90                  my $a;                                          my $rows = $#{ $data->{rows} } + 1;
91                  my @attrs = map {  $a->{$_}++; $_ } $self->attribute_order;                                          $rows ||= 'no';
92                  push @attrs, $_ foreach grep { ! $a->{$_} } map { $_->name } @required;                                          $body .= "<strong>$rows</strong> rows from <code>$class->new" . dump( $self->params ) . "->sponge</code>";
93                  warn "# attrs = ",dump( @attrs );                                          $body .= '<table>';
94                                            $body .= '<tr><th>' . join('</th><th>', @{$data->{NAME}} ) . '</th></tr>';
95                  foreach my $name ( @attrs ) {                                          $body .= '<tr><td>' . join('</td><td>', @$_ ) . '</td></tr>' foreach @{ $data->{rows} };
96                          my $attr = $class->meta->get_attribute( $name );                                          $body .= '</table>';
97                          my $type = $name =~ m/^pass/ ? 'password' : 'text';                                  }
98                          my $value =                          } elsif ( $self->run eq 'data' ) {
99                                  $values ? $values->{$name} :                                  $data = $o->data;
100                                  $attr->has_default ? $attr->default( $name ) :                          } else {
101                                  '';                                  $body = $self->error( "IGNORE: $class ", $o->dump );
 #warn "# required $name ", $class->meta->get_attribute( $name )->dump( 2 );  
                         $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( %{ $self->params } );  
                 $o->depends if $o->can('depends');  
                 if ( $o->can('markup') ) {  
                         warn "## using ",ref($o), "->markup";  
                         $html = eval { $o->markup };  
                         if ( $@ ) {  
                                 warn $@;  
                                 $html .= qq{<code>$@</code>};  
102                          }                          }
                         warn ">>> markup $class ",length( $html ), " bytes\n";  
                 } elsif ( $o->can('data') ) {  
                         my $data = $o->data;  
                         $html .= Frey::Dumper->new( data => $data )->markup;  
                         $html .= '<hr/><code>' . $self->html_dump( $data ) . '</code>';  
                 } else {  
                         $html = "IGNORE: $class ", $o->dump;  
                         warn $html;  
                 }  
         }  
103    
104          return $self->page( title => $class, body => $html );                          if ( defined $data ) {
105                                    $html .= to_json( $data ) if $self->format =~ m{js(on)?};
106                                    $html .= Dump( $data )    if $self->format =~ m{ya?ml};
107                                    push @{ $self->status }, { 'data' => $data };
108                            }
109                            if ( ! $html ) {
110                                    $body .= Frey::Dumper->new( data => $data )->markup;
111                            }
112    
113                            # override our status with one from object
114                            $self->status( $o->status ) if $o->can('status') && $o->status;
115                    };
116    
117    
118                    if ( ref($body) eq 'HASH' ) {
119                            $html = $self->page( %$body );
120                    } elsif ( $body && ! $html ) {
121                            $html = $self->page( title => $self->class . ' run', body => $body );
122                    };
123            };
124    
125            $html = $self->page( title => $self->class, body => dump($html) . $self->error( $@ ) ) if $@;
126    
127            return $html;
128  }  }
129    
130  1;  1;

Legend:
Removed from v.336  
changed lines
  Added in v.421

  ViewVC Help
Powered by ViewVC 1.1.26