/[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 354 by dpavlin, Sun Nov 16 14:17:18 2008 UTC revision 519 by dpavlin, Tue Nov 25 17:15:18 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    with 'Frey::Session';
8    
9  use Data::Dump qw/dump/;  use Data::Dump qw/dump/;
10  use Frey::Dumper;  use Frey::View::Dumper;
11    use JSON;
12    use YAML;
13    
14  =head1 NAME  =head1 NAME
15    
# Line 18  Frey::Run - display required form field Line 20  Frey::Run - display required form field
20  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
21  will try to invoke C<data>, and C<markup> method on the.  will try to invoke C<data>, and C<markup> method on the.
22    
23    =head1 SEE ALSO
24    
25    L<Frey::Action> which creates form for params
26    
27  =cut  =cut
28    
29  use Moose::Util::TypeConstraints;  use Moose::Util::TypeConstraints;
30    
31  enum 'Runnable' => qw/data markup sponge/;  subtype 'Runnable'
32            => as 'Str',
33            => where sub { m{^as_} };
34    
35  sub runnable { qw/data markup sponge/ }  sub formats_available { qw/html js json yaml yml/ }
36    enum 'Formats' => formats_available;
37    
38  has 'class' => (  has 'class' => (
39          is => 'rw',          is => 'rw',
# Line 41  has 'params' => ( Line 50  has 'params' => (
50  has 'run' => (  has 'run' => (
51          is => 'rw',          is => 'rw',
52          isa => 'Runnable',          isa => 'Runnable',
53          default => 'markup',          default => 'as_markup',
54    );
55    
56    has 'format' => (
57            is => 'rw',
58            isa => 'Formats',
59            default => 'html',
60  );  );
61    
62  sub html {  sub html {
63          my ( $self ) = @_;          my ( $self ) = @_;
64    
65          my $class = $self->class;          my ($html,$body,$data);
66            eval {
67                    my $class = $self->class;
68                    $self->load_class( $class );
69    
70                    if ( $body = $self->params_form ) {
71                            warn "got required params form for $class ", $self->run, " format: ", $self->format;
72                    } else {
73    
74          $self->load_class( $class );                          $self->usage->{ $class }++;
75    
         my @required =  
                 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;  
   
 #warn "# required $name ", $class->meta->get_attribute( $name )->dump( 2 );  
                         $html .= qq|<label for="$name">$name</label>| . $value_html;  
                 }  
                 $html .= qq|<input type="submit" value="Run $class"></form>|;  
         } else {  
                 eval {  
76                          my $o;                          my $o;
77                          $o = $class->new( %{ $self->params } );                          my ( $meta, $is_role, $instance ) = $self->class_meta( $class );
78                            if ( $is_role ) {
79                                    $o = $instance;
80                            } else {
81                                    $o = $self->new_frey_class( $class, $self->params );
82                            }
83    
84                          $o->depends if $o->can('depends');                          $o->depends if $o->can('depends');
85    
86                          if ( $self->run eq 'markup' ) {                          my @status;
87                                  warn "## using ",ref($o), "->markup";  
88                                  $html = $o->markup;                          push @status, { $self->editor( $class ) => $self->params };
89                                  warn ">>> markup $class ",length( $html ), " bytes\n";  
90                          } elsif ( $self->run eq 'sponge' ) {                          if ( $self->run eq 'as_markup' && ! $o->can('page') ) {
91                                  my $data = $o->sponge;                                  warn "## using ",ref($o), "->as_markup";
92                                    $body = $o->as_markup unless $html;
93                                    warn ">>> markup $class ",length( $body ), " ", $html ? 'html' : 'body', " bytes";
94                            } elsif ( $self->run eq 'as_sponge' ) {
95                                    $data = $o->as_sponge;
96                                  confess "invalid data from sponge = ", dump( $data ) unless ref($data) eq 'HASH';                                  confess "invalid data from sponge = ", dump( $data ) unless ref($data) eq 'HASH';
97                                  $html .= "<strong>" . $#{ $data->{rows} } . "</strong> rows from <code>$class->new" . dump( $self->params ) . "->sponge</code>";                                  if ( $self->format eq 'html' ) {
98                                  $html .= '<table>';                                          my $rows = $#{ $data->{rows} } + 1;
99                                  $html .= '<tr><th>' . join('</th><th>', @{$data->{NAME}} ) . '</th></tr>';                                          $rows ||= 'no';
100                                  $html .= '<tr><td>' . join('</td><td>', @$_ ) . '</td></tr>' foreach @{ $data->{rows} };                                          $body .= "<strong>$rows</strong> rows from <code>$class->new" . dump( $self->params ) . "->as_sponge</code>";
101                                  $html .= '</table>';                                          $body .= '<table>';
102                          } elsif ( $self->run eq 'data' ) {                                          $body .= '<tr><th>' . join('</th><th>', @{$data->{NAME}} ) . '</th></tr>';
103                                  my $data = $o->data;                                          $body .= '<tr><td>' . join('</td><td>', @$_ ) . '</td></tr>' foreach @{ $data->{rows} };
104                                  $html .= Frey::Dumper->new( data => $data )->markup;                                          $body .= '</table>';
105                                  $html .= '<hr/><code>' . $self->html_dump( $data ) . '</code>';                                  }
106                            } elsif ( $self->run eq 'as_data' ) {
107                                    $data = $o->as_data;
108                            } else {
109                                    $body = $self->error( "IGNORE: $class ", $o->dump );
110                            }
111    
112                            if ( defined $data ) {
113                                    $html .= to_json( $data ) if $self->format =~ m{js(on)?};
114                                    $html .= Dump( $data )    if $self->format =~ m{ya?ml};
115                                    push @status, { 'data' => $data };
116                            }
117                            if ( ! $html ) {
118                                    $body  = Frey::View::Dumper->new( data => $body )->as_markup if ref $body;
119                                    $body .= Frey::View::Dumper->new( data => $data )->as_markup if defined $data;
120                            }
121    
122                            warn "## status from $self ",dump(@status);
123    
124                            if ( $o->can('add_status') ) {
125                                    $o->add_status($_) foreach @status;
126                            }
127    
128                            if ( $self->run eq 'as_markup' && $o->can('page') ) {
129                                    $html = $o->page;
130                                    warn "got ", length($html), " for page from $o it's status is ", dump( $o->status );
131                          } else {                          } else {
132                                  $html = $self->error( "IGNORE: $class ", $o->dump );                                  $self->add_status($_) foreach @status;
133                          }                          }
134                  };                  };
135    
136                  $html .= $self->error( $@ ) if $@;                  if ( ref($body) eq 'HASH' ) {
137          }                          $html = $self->page( %$body );
138                            warn "WARNING: old calling convention with HASH which is depriciated but produced ", length($html), " bytes";
139                    } elsif ( $body && ! $html ) {
140                            $html = $self->page( title => $self->class . ' run', body => $body );
141                            warn "wrap body of ",length($body), " in page with ", length($html), " bytes";
142                    };
143            };
144    
145            $self->status_parts;
146    
147            $html = $self->page( title => $self->class, body => $self->error( $@ ) ) if $@;
148    
149          return $self->page( title => $class, body => $html );          return $html;
150  }  }
151    
152  1;  1;

Legend:
Removed from v.354  
changed lines
  Added in v.519

  ViewVC Help
Powered by ViewVC 1.1.26