/[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 349 by dpavlin, Sun Nov 16 00:25:39 2008 UTC revision 1128 by dpavlin, Tue Jun 30 14:13:15 2009 UTC
# Line 1  Line 1 
1  package Frey::Run;  package Frey::Run;
2  use Moose;  use Moose;
3  #extends 'Frey::ClassLoader';  #extends 'Frey::Class::Loader';
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 JSON;
9    use YAML;
10    
11    use lib 'lib';
12    use Frey::View::Dumper;
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    use Frey::Class::Loader; # class_runnable_re
31    
32  enum 'Runnable' => qw/data markup sponge/;  subtype 'Runnable'
33            => as 'Str',
34            => where sub { Frey::Class::Loader::class_runnable_re };
35    
36  sub runnable { qw/data markup sponge/ }  sub formats_available { qw/html js json yaml yml/ }
37    enum 'Formats' => formats_available;
38    
39  has 'class' => (  has 'class' => (
40          is => 'rw',          is => 'rw',
# Line 41  has 'params' => ( Line 51  has 'params' => (
51  has 'run' => (  has 'run' => (
52          is => 'rw',          is => 'rw',
53          isa => 'Runnable',          isa => 'Runnable',
54            default => 'as_markup',
55    );
56    
57    has 'format' => (
58            is => 'rw',
59            isa => 'Formats',
60            default => 'html',
61    );
62    
63    has 'request_url' => (
64            documentation => 'Take url from params if not specified',
65            is => 'rw',
66            isa => 'Uri', coerce => 1,
67            lazy => 1,
68            default => sub {
69                    my $self = shift;
70                    $self->params->{request_url};
71            },
72  );  );
73    
74  sub html {  sub html {
75          my ( $self ) = @_;          my ( $self ) = @_;
76    
77          my $class = $self->class;          my ($html,$body,$data);
78    
79            my $current_status;
80            $current_status->{$_}++ foreach $self->status;
81    
82            eval {
83                    my $class = $self->class;
84                    $self->load_class( $class );
85    
86                    if ( my $form = $self->params_form ) {
87                            $html = $self->html_page( body => $form );
88                            warn "missing required params form for $class ", $self->run, " format: ", $self->format;
89                    } else {
90    
91                            $self->usage->{ $class }++;
92    
93          $self->load_class( $class );  =begin remove
94    
95          my @required =                          my $o;
96                  grep {                          my ( $meta, $is_role, $instance ) = $self->class_meta( $class );
97                          defined $_ && $_->can('name') && !defined( $self->params->{ $_->name } )                          if ( $is_role ) {
98                  }                                  $o = $instance;
99                  map {                                  if ( $o->can('add_status') ) {
100                          my $attr = $class->meta->get_attribute($_);                                          $self->TODO("missing add_status in $o");
101                          $attr->is_required && $attr;                                          Frey::Web->meta->apply( $o );
102                  } $class->meta->get_attribute_list;                                          warn "# apply Frey::Web to $class instance $o";
103                                    }
104          warn "## required = ",dump( map { $_->name } @required ), " for $class";                          } else {
105                                    $o = $self->new_frey_class( $class, $self->params );
         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 );  
106                          }                          }
107                          $value_html = qq|<input type="$type" name="$name" value="$value">| unless $value_html;  =cut
108    
109  #warn "# required $name ", $class->meta->get_attribute( $name )->dump( 2 );                          my $o = $self->new_frey_class( $class, $self->params );
110                          $html .= qq|<label for="$name">$name</label>| . $value_html;                          $o->depends if $o->can('depends');
111                  }  
112                  $html .= qq|<input type="submit" value="Run $class"></form>|;                          if ( $self->run =~ m{as_markup} ) {
113          } else {                                  $html = $o->html_page( run => $self->run );
114                  my $o = $class->new( %{ $self->params } );                          } elsif ( $self->run =~ m{(.*as_sponge)} ) {
115                  $o->depends if $o->can('depends');                                  $data = $o->$1;
116                  if ( $o->can('markup') ) {                                  confess "invalid data from sponge = ", dump( $data ) unless ref($data) eq 'HASH';
117                          warn "## using ",ref($o), "->markup";                                  if ( $self->format eq 'html' ) {
118                          $html = eval { $o->markup };                                          my $rows = $#{ $data->{rows} } + 1;
119                          if ( $@ ) {                                          $rows ||= 'no';
120                                  warn $@;                                          $body .= "<strong>$rows</strong> rows from <code>$class->new" . dump( $self->params ) . "->as_sponge</code>";
121                                  $html .= qq{<code>$@</code>};                                          $body .= '<table>';
122                                            $body .= '<tr><th>' . join('</th><th>', @{$data->{NAME}} ) . '</th></tr>';
123                                            $body .= '<tr><td>' . join('</td><td>', @$_ ) . '</td></tr>' foreach @{ $data->{rows} };
124                                            $body .= '</table>';
125    
126                                            $self->add_css(qq|
127                                                    tr:nth-child(even) {
128                                                            background-color: #eee;
129                                                    }
130                                            |);
131    
132                                            delete( $data->{rows} ); # too much dumplication
133                                            $body .= Frey::View::Dumper->new( data => $data )->as_markup if $data;
134                                    }
135                            } elsif ( $self->run =~ m{(as_data|sql)} ) {
136                                    my $run = $self->run;
137                                    $data = $o->$run;
138                                    confess "no data for $class->$run" unless defined $data;
139                                    $self->add_status( { $self->run => $data } );
140                            } else {
141                                    $body = $self->error( "IGNORE: $class ", $o->dump );
142                          }                          }
143                          warn ">>> markup $class ",length( $html ), " bytes\n";  
144                  } elsif ( $o->can('sponge') ) {                          if ( defined $data ) {
145                          my $data = $o->sponge;                                  $html .= to_json( $data ) if $self->format =~ m{js(on)?};
146                          $html .= '<table>';                                  $html .= Dump( $data )    if $self->format =~ m{ya?ml};
147                          $html .= '<tr><th>' . join('</th><th>', @{$data->{NAME}} ) . '</th></tr>';                          }
148                          $html .= '<tr><td>' . join('</td><td>', @$_ ) . '</td></tr>' foreach @{ $data->{rows} };                          if ( ! $html ) {
149                          $html .= '</table>';                                  $body  = Frey::View::Dumper->new( data => $body )->as_markup if ref $body;
150                  } elsif ( $o->can('data') ) {                                  $body .= Frey::View::Dumper->new( data => $data )->as_markup if defined $data && ! defined $body;
151                          my $data = $o->data;                          }
152                          $html .= Frey::Dumper->new( data => $data )->markup;  
153                          $html .= '<hr/><code>' . $self->html_dump( $data ) . '</code>';                          $o->title( $class );
154                  } else {  
155                          $html = "IGNORE: $class ", $o->dump;                          $html = $o->html_page( body => $body ) if $body && !$html;
156                          warn $html;                          $self->content_type( $o->content_type );
157                  }  
158                            confess "no html output for $class ", $o->dump unless defined $html;
159    
160                            if ( $o->can('status') ) {
161                                    foreach ( $o->status ) {
162                                            next if $current_status->{$_}++;
163                                            $self->add_status( $_ );
164    #                                       warn "# run add_status: ", $self->dump( $_ ); # FIXME
165                                    }
166                            }
167    
168                    };
169    
170            };
171    
172            $self->status_parts;
173    
174            if ( $@ ) {
175                    my $error = $@;
176                    warn $error;
177    
178                    exit if $error =~ m{Attempt to reload \S+ aborted}; # FIXME Mojo can't reload DBIx::Class
179    
180                    my $o = Frey->new;
181                    $o->{request_url} = $self->request_url; # sigh, this is dynamic languge, right?
182                    Frey::Web->meta->apply( $o );
183                    $html = $o->html_page( body => $self->error( $error, undef ) );
184          }          }
185    
186          return $self->page( title => $class, body => $html );          warn $self->class, " produced ", length($html), " bytes of ", $self->content_type;
187    
188            return $html;
189  }  }
190    
191  1;  1;

Legend:
Removed from v.349  
changed lines
  Added in v.1128

  ViewVC Help
Powered by ViewVC 1.1.26