/[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 350 by dpavlin, Sun Nov 16 00:37:34 2008 UTC revision 423 by dpavlin, Tue Nov 18 19:50:45 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    use YAML;
12    
13  =head1 NAME  =head1 NAME
14    
# Line 18  Frey::Run - display required form field Line 19  Frey::Run - display required form field
19  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
20  will try to invoke C<data>, and C<markup> method on the.  will try to invoke C<data>, and C<markup> method on the.
21    
22    =head1 SEE ALSO
23    
24    L<Frey::Action> which creates form for params
25    
26  =cut  =cut
27    
28  use Moose::Util::TypeConstraints;  use Moose::Util::TypeConstraints;
29    
30  enum 'Runnable' => qw/data markup sponge/;  sub runnable { qw/data data.js markup sponge/ }
31    enum 'Runnable' => runnable;
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',
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 ( $body = $self->params_form ) {
69                            warn "got required params form for $class ", $self->run, " format: ", $self->format;
70                    } else {
71    
72          $self->load_class( $class );                          my $o = $class->new( %{ $self->params } );
73                            $o->depends if $o->can('depends');
74    
75          my @required =                          push @{ $self->status }, { qq|<a target="editor" href="/editor+$class+1">$class</a>| => $self->params };
76                  grep {  
77                          defined $_ && $_->can('name') && !defined( $self->params->{ $_->name } )                          if ( $self->run eq 'markup' ) {
78                  }                                  warn "## using ",ref($o), "->markup";
79                  map {                                  if ( $o->can('page') ) {
80                          my $attr = $class->meta->get_attribute($_);                                          #$html = $o->page;
81                          $attr->is_required && $attr;                                          $body = $o->markup unless $html;
82                  } $class->meta->get_attribute_list;                                  } else {
83                                            $body = $o->markup;
84          warn "## required = ",dump( map { $_->name } @required ), " for $class";                                  }
85    
86          my $html;                                  warn ">>> markup $class ",length( $html || $body ), " ", $html ? 'html' : 'body', " bytes";
87          my $values = {};                          } elsif ( $self->run eq 'sponge' ) {
88          $values = $self->config($class);                                  $data = $o->sponge;
89          warn "# $class config = ",dump( $values );                                  confess "invalid data from sponge = ", dump( $data ) unless ref($data) eq 'HASH';
90                                    if ( $self->format eq 'html' ) {
91          if ( @required ) {                                          my $rows = $#{ $data->{rows} } + 1;
92                  $html = qq|<h1>$class params</h1><form method="post">|;                                          $rows ||= 'no';
93                                            $body .= "<strong>$rows</strong> rows from <code>$class->new" . dump( $self->params ) . "->sponge</code>";
94                  my $a;                                          $body .= '<table>';
95                  my @attrs = map {  $a->{$_}++; $_ } $self->attribute_order;                                          $body .= '<tr><th>' . join('</th><th>', @{$data->{NAME}} ) . '</th></tr>';
96                  push @attrs, $_ foreach grep { ! $a->{$_} } map { $_->name } @required;                                          $body .= '<tr><td>' . join('</td><td>', @$_ ) . '</td></tr>' foreach @{ $data->{rows} };
97                  warn "# attrs = ",dump( @attrs );                                          $body .= '</table>';
98                                    }
99                  foreach my $name ( @attrs ) {                          } elsif ( $self->run eq 'data' ) {
100                          my $attr = $class->meta->get_attribute( $name );                                  $data = $o->data;
101                          my $type = $name =~ m/^pass/ ? 'password' : 'text';                          } else {
102                          my $value = '';                                  $body = $self->error( "IGNORE: $class ", $o->dump );
                         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 );  
103                          }                          }
                         $value_html = qq|<input type="$type" name="$name" value="$value">| unless $value_html;  
104    
105  #warn "# required $name ", $class->meta->get_attribute( $name )->dump( 2 );                          if ( defined $data ) {
106                          $html .= qq|<label for="$name">$name</label>| . $value_html;                                  $html .= to_json( $data ) if $self->format =~ m{js(on)?};
107                  }                                  $html .= Dump( $data )    if $self->format =~ m{ya?ml};
108                  $html .= qq|<input type="submit" value="Run $class"></form>|;                                  push @{ $self->status }, { 'data' => $data };
109          } else {                          }
110                  my $o = $class->new( %{ $self->params } );                          if ( ! $html ) {
111                  $o->depends if $o->can('depends');                                  $body .= Frey::Dumper->new( data => $data )->markup;
112                  if ( $o->can('markup') ) {                          }
113                          warn "## using ",ref($o), "->markup";  
114                          $html = eval { $o->markup };                          # override our status with one from object
115                          $html .= $self->error( $@ ) if $@;                          eval {
116                          warn ">>> markup $class ",length( $html ), " bytes\n";                                  $self->status( $o->status );
117                  } elsif ( $o->can('sponge') ) {                          };
118                          my $data = $o->sponge;                          warn "can't override status: $@" if $@;
119                          $html .= '<table>';                  };
120                          $html .= '<tr><th>' . join('</th><th>', @{$data->{NAME}} ) . '</th></tr>';  
121                          $html .= '<tr><td>' . join('</td><td>', @$_ ) . '</td></tr>' foreach @{ $data->{rows} };  
122                          $html .= '</table>';                  if ( ref($body) eq 'HASH' ) {
123                  } elsif ( $o->can('data') ) {                          $html = $self->page( %$body );
124                          my $data = $o->data;                  } elsif ( $body && ! $html ) {
125                          $html .= Frey::Dumper->new( data => $data )->markup;                          $html = $self->page( title => $self->class . ' run', body => $body );
126                          $html .= '<hr/><code>' . $self->html_dump( $data ) . '</code>';                  };
127                  } else {          };
128                          $html = "IGNORE: $class ", $o->dump;  
129                          warn $html;          $html = $self->page( title => $self->class, body => dump($html) . $self->error( $@ ) ) if $@;
                 }  
         }  
130    
131          return $self->page( title => $class, body => $html );          return $html;
132  }  }
133    
134  1;  1;

Legend:
Removed from v.350  
changed lines
  Added in v.423

  ViewVC Help
Powered by ViewVC 1.1.26