/[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 348 by dpavlin, Sat Nov 15 23:52:22 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::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  sub runnable { qw/data markup sponge/ }  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 34  has 'params' => ( Line 45  has 'params' => (
45          default => sub { {} },          default => sub { {} },
46  );  );
47    
48    has 'run' => (
49            is => 'rw',
50            isa => 'Runnable',
51            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 ( $self->params_form ) {
69                            $html = $self->page;
70                            warn "got required params form for $class ", $self->run, " format: ", $self->format;
71                    } else {
72    
73                            $self->usage->{ $class }++;
74    
75          $self->load_class( $class );                          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          my @required =                          $o->add_status( { $self->editor( $class ) => $self->params } );
86                  grep {  
87                          defined $_ && $_->can('name') && !defined( $self->params->{ $_->name } )                          if ( $self->run =~ m{as_markup} ) {
88                  }                                  $html = $o->page;
89                  map {                          } elsif ( $self->run =~ m{as_sponge} ) {
90                          my $attr = $class->meta->get_attribute($_);                                  $data = $o->as_sponge;
91                          $attr->is_required && $attr;                                  confess "invalid data from sponge = ", dump( $data ) unless ref($data) eq 'HASH';
92                  } $class->meta->get_attribute_list;                                  if ( $self->format eq 'html' ) {
93                                            my $rows = $#{ $data->{rows} } + 1;
94          warn "## required = ",dump( map { $_->name } @required ), " for $class";                                          $rows ||= 'no';
95                                            $body .= "<strong>$rows</strong> rows from <code>$class->new" . dump( $self->params ) . "->as_sponge</code>";
96          my $html;                                          $body .= '<table>';
97          my $values = {};                                          $body .= '<tr><th>' . join('</th><th>', @{$data->{NAME}} ) . '</th></tr>';
98          $values = $self->config($class);                                          $body .= '<tr><td>' . join('</td><td>', @$_ ) . '</td></tr>' foreach @{ $data->{rows} };
99          warn "# $class config = ",dump( $values );                                          $body .= '</table>';
100                                    }
101          if ( @required ) {                          } elsif ( $self->run =~ m{as_data} ) {
102                  $html = qq|<h1>$class params</h1><form method="post">|;                                  $data = $o->as_data;
   
                 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>|;  
103                          } else {                          } else {
104                                  $value = $attr->default( $name ) if $attr->has_default;                                  $body = $self->error( "IGNORE: $class ", $o->dump );
105                          }                          }
                         $value_html = qq|<input type="$type" name="$name" value="$value">| unless $value_html;  
106    
107  #warn "# required $name ", $class->meta->get_attribute( $name )->dump( 2 );                          if ( defined $data ) {
108                          $html .= qq|<label for="$name">$name</label>| . $value_html;                                  $html .= to_json( $data ) if $self->format =~ m{js(on)?};
109                  }                                  $html .= Dump( $data )    if $self->format =~ m{ya?ml};
110                  $html .= qq|<input type="submit" value="Run $class"></form>|;                                  $self->add_status( { 'data' => $data } );
         } 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>};  
111                          }                          }
112                          warn ">>> markup $class ",length( $html ), " bytes\n";                          if ( ! $html ) {
113                  } elsif ( $o->can('sponge') ) {                                  $body  = Frey::View::Dumper->new( data => $body )->as_markup if ref $body;
114                          my $data = $o->sponge;                                  $body .= Frey::View::Dumper->new( data => $data )->as_markup if defined $data;
115                          $html .= '<table>';                          }
116                          $html .= '<tr><th>' . join('</th><th>', @{$data->{NAME}} ) . '</th></tr>';  
117                          $html .= '<tr><td>' . join('</td><td>', @$_ ) . '</td></tr>' foreach @{ $data->{rows} };                          $self->title( $class );
118                          $html .= '</table>';  
119                  } elsif ( $o->can('data') ) {                          $html = $o->page( body => $body ) if $body && !$html;
120                          my $data = $o->data;                  };
121                          $html .= Frey::Dumper->new( data => $data )->markup;  
122                          $html .= '<hr/><code>' . $self->html_dump( $data ) . '</code>';          };
123                  } else {  
124                          $html = "IGNORE: $class ", $o->dump;          $self->status_parts;
125                          warn $html;  
126                  }          $html = $self->error( $@ ) if $@;
127          }  
128            warn $self->class, " produced ", length($html), " bytes";
129    
130          return $self->page( title => $class, body => $html );          return $html;
131  }  }
132    
133  1;  1;

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

  ViewVC Help
Powered by ViewVC 1.1.26