/[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 934 by dpavlin, Tue Jan 6 00:22:56 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  sub runnable { qw/data markup sponge/ }  use Moose::Util::TypeConstraints;
30    use Frey::Class::Loader; # class_runnable_re
31    
32    subtype 'Runnable'
33            => as 'Str',
34            => where sub { Frey::Class::Loader::class_runnable_re };
35    
36    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 34  has 'params' => ( Line 48  has 'params' => (
48          default => sub { {} },          default => sub { {} },
49  );  );
50    
51    has 'run' => (
52            is => 'rw',
53            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->page( body => $form );
88                            warn "got 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                                    }
         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>|;  
104                          } else {                          } else {
105                                  $value = $attr->default( $name ) if $attr->has_default;                                  $o = $self->new_frey_class( $class, $self->params );
106                          }                          }
107                          $value_html = qq|<input type="$type" name="$name" value="$value">| unless $value_html;  =cut
108    
109                            my $o = $self->new_frey_class( $class, $self->params );
110                            $o->depends if $o->can('depends');
111    
112  #warn "# required $name ", $class->meta->get_attribute( $name )->dump( 2 );                          if ( $self->run =~ m{as_markup} ) {
113                          $html .= qq|<label for="$name">$name</label>| . $value_html;                                  $html = $o->page( run => $self->run );
114                  }                          } elsif ( $self->run =~ m{(.*as_sponge)} ) {
115                  $html .= qq|<input type="submit" value="Run $class"></form>|;                                  $data = $o->$1;
116          } else {                                  confess "invalid data from sponge = ", dump( $data ) unless ref($data) eq 'HASH';
117                  my $o = $class->new( %{ $self->params } );                                  if ( $self->format eq 'html' ) {
118                  $o->depends if $o->can('depends');                                          my $rows = $#{ $data->{rows} } + 1;
119                  if ( $o->can('markup') ) {                                          $rows ||= 'no';
120                          warn "## using ",ref($o), "->markup";                                          $body .= "<strong>$rows</strong> rows from <code>$class->new" . dump( $self->params ) . "->as_sponge</code>";
121                          $html = eval { $o->markup };                                          $body .= '<table>';
122                          if ( $@ ) {                                          $body .= '<tr><th>' . join('</th><th>', @{$data->{NAME}} ) . '</th></tr>';
123                                  warn $@;                                          $body .= '<tr><td>' . join('</td><td>', @$_ ) . '</td></tr>' foreach @{ $data->{rows} };
124                                  $html .= qq{<code>$@</code>};                                          $body .= '</table>';
125                                            
126                                            delete( $data->{rows} ); # too much dumplication
127                                            $body .= Frey::View::Dumper->new( data => $data )->as_markup if $data;
128                                    }
129                            } elsif ( $self->run =~ m{(as_data|sql)} ) {
130                                    my $run = $self->run;
131                                    $data = $o->$run;
132                                    confess "no data for $class->$run" unless defined $data;
133                                    $self->add_status( { $self->run => $data } );
134                            } else {
135                                    $body = $self->error( "IGNORE: $class ", $o->dump );
136                          }                          }
137                          warn ">>> markup $class ",length( $html ), " bytes\n";  
138                  } elsif ( $o->can('sponge') ) {                          if ( defined $data ) {
139                          my $data = $o->sponge;                                  $html .= to_json( $data ) if $self->format =~ m{js(on)?};
140                          $html .= '<table>';                                  $html .= Dump( $data )    if $self->format =~ m{ya?ml};
141                          $html .= '<tr><th>' . join('</th><th>', @{$data->{NAME}} ) . '</th></tr>';                          }
142                          $html .= '<tr><td>' . join('</td><td>', @$_ ) . '</td></tr>' foreach @{ $data->{rows} };                          if ( ! $html ) {
143                          $html .= '</table>';                                  $body  = Frey::View::Dumper->new( data => $body )->as_markup if ref $body;
144                  } elsif ( $o->can('data') ) {                                  $body .= Frey::View::Dumper->new( data => $data )->as_markup if defined $data && ! defined $body;
145                          my $data = $o->data;                          }
146                          $html .= Frey::Dumper->new( data => $data )->markup;  
147                          $html .= '<hr/><code>' . $self->html_dump( $data ) . '</code>';                          $o->title( $class );
148                  } else {  
149                          $html = "IGNORE: $class ", $o->dump;                          $html = $o->page( body => $body ) if $body && !$html;
150                          warn $html;                          $self->content_type( $o->content_type );
151                  }  
152                            confess "no html output for $class ", $o->dump unless defined $html;
153    
154                            if ( $o->can('status') ) {
155                                    foreach ( $o->status ) {
156                                            next if $current_status->{$_}++;
157                                            $self->add_status( $_ );
158                                            warn "# run add_status: ", $self->dump( $_ );
159                                    }
160                            }
161    
162                    };
163    
164            };
165    
166            $self->status_parts;
167    
168            if ( $@ ) {
169                    my $error = $@;
170                    my $o = Frey->new;
171                    $o->{request_url} = $self->request_url; # sigh, this is dynamic languge, right?
172                    Frey::Web->meta->apply( $o );
173                    $html = $o->page( body => $self->error( $error, undef ) );
174          }          }
175    
176          return $self->page( title => $class, body => $html );          warn $self->class, " produced ", length($html), " bytes of ", $self->content_type;
177    
178            return $html;
179  }  }
180    
181  1;  1;

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

  ViewVC Help
Powered by ViewVC 1.1.26