/[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 835 by dpavlin, Sun Dec 14 14:13:35 2008 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 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  use Moose::Util::TypeConstraints;  use Moose::Util::TypeConstraints;
28    
29  enum 'Runnable' => qw/data markup sponge/;  subtype 'Runnable'
30            => as 'Str',
31            => where sub { m{^as_} || m{_as_} };
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 => 'as_markup',
52    );
53    
54    has 'format' => (
55            is => 'rw',
56            isa => 'Formats',
57            default => 'html',
58    );
59    
60    has 'request_url' => (
61            documentation => 'Take url from params if not specified',
62            is => 'rw',
63            isa => 'Uri', coerce => 1,
64            lazy => 1,
65            default => sub {
66                    my $self = shift;
67                    $self->params->{request_url};
68            },
69  );  );
70    
71  sub html {  sub html {
72          my ( $self ) = @_;          my ( $self ) = @_;
73    
74          my $class = $self->class;          my ($html,$body,$data);
75            eval {
76                    my $class = $self->class;
77                    $self->load_class( $class );
78    
79                    if ( my $form = $self->params_form ) {
80                            $html = $self->page( body => $form );
81                            warn "got required params form for $class ", $self->run, " format: ", $self->format;
82                    } else {
83    
84                            $self->usage->{ $class }++;
85    
86          $self->load_class( $class );  =begin remove
87    
88          my @required =                          my $o;
89                  grep {                          my ( $meta, $is_role, $instance ) = $self->class_meta( $class );
90                          defined $_ && $_->can('name') && !defined( $self->params->{ $_->name } )                          if ( $is_role ) {
91                  }                                  $o = $instance;
92                  map {                                  if ( $o->can('add_status') ) {
93                          my $attr = $class->meta->get_attribute($_);                                          $self->TODO("missing add_status in $o");
94                          $attr->is_required && $attr;                                          Frey::Web->meta->apply( $o );
95                  } $class->meta->get_attribute_list;                                          warn "# apply Frey::Web to $class instance $o";
96                                    }
97          warn "## required = ",dump( map { $_->name } @required ), " for $class";                          } else {
98                                    $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 );  
99                          }                          }
100                          $value_html = qq|<input type="$type" name="$name" value="$value">| unless $value_html;  =cut
101    
102                            my $o = $self->new_frey_class( $class, $self->params );
103                            $o->depends if $o->can('depends');
104    
105  #warn "# required $name ", $class->meta->get_attribute( $name )->dump( 2 );                          if ( $self->run =~ m{as_markup} ) {
106                          $html .= qq|<label for="$name">$name</label>| . $value_html;                                  $html = $o->page( run => $self->run );
107                  }                          } elsif ( $self->run =~ m{as_sponge} ) {
108                  $html .= qq|<input type="submit" value="Run $class"></form>|;                                  $data = $o->as_sponge;
109          } else {                                  confess "invalid data from sponge = ", dump( $data ) unless ref($data) eq 'HASH';
110                  my $o = $class->new( %{ $self->params } );                                  if ( $self->format eq 'html' ) {
111                  $o->depends if $o->can('depends');                                          my $rows = $#{ $data->{rows} } + 1;
112                  if ( $o->can('markup') ) {                                          $rows ||= 'no';
113                          warn "## using ",ref($o), "->markup";                                          $body .= "<strong>$rows</strong> rows from <code>$class->new" . dump( $self->params ) . "->as_sponge</code>";
114                          $html = eval { $o->markup };                                          $body .= '<table>';
115                          if ( $@ ) {                                          $body .= '<tr><th>' . join('</th><th>', @{$data->{NAME}} ) . '</th></tr>';
116                                  warn $@;                                          $body .= '<tr><td>' . join('</td><td>', @$_ ) . '</td></tr>' foreach @{ $data->{rows} };
117                                  $html .= qq{<code>$@</code>};                                          $body .= '</table>';
118                                    }
119                            } elsif ( $self->run =~ m{as_data} ) {
120                                    my $run = $self->run;
121                                    $data = $o->$run;
122                                    confess "no data for $class->$run" unless defined $data;
123                                    $self->add_status( { $self->run => $data } );
124                            } else {
125                                    $body = $self->error( "IGNORE: $class ", $o->dump );
126                          }                          }
127                          warn ">>> markup $class ",length( $html ), " bytes\n";  
128                  } elsif ( $o->can('sponge') ) {                          if ( defined $data ) {
129                          my $data = $o->sponge;                                  $html .= to_json( $data ) if $self->format =~ m{js(on)?};
130                          $html .= '<table>';                                  $html .= Dump( $data )    if $self->format =~ m{ya?ml};
131                          $html .= '<tr><th>' . join('</th><th>', @{$data->{NAME}} ) . '</th></tr>';                          }
132                          $html .= '<tr><td>' . join('</td><td>', @$_ ) . '</td></tr>' foreach @{ $data->{rows} };                          if ( ! $html ) {
133                          $html .= '</table>';                                  $body  = Frey::View::Dumper->new( data => $body )->as_markup if ref $body;
134                  } elsif ( $o->can('data') ) {                                  $body .= Frey::View::Dumper->new( data => $data )->as_markup if defined $data;
135                          my $data = $o->data;                          }
136                          $html .= Frey::Dumper->new( data => $data )->markup;  
137                          $html .= '<hr/><code>' . $self->html_dump( $data ) . '</code>';                          $o->title( $class );
138                  } else {  
139                          $html = "IGNORE: $class ", $o->dump;                          $html = $o->page( body => $body ) if $body && !$html;
140                          warn $html;                          $self->content_type( $o->content_type );
141                  }  
142                            confess "no html output for $class ", $o->dump unless defined $html;
143                    };
144    
145            };
146    
147            $self->status_parts;
148    
149            if ( $@ ) {
150                    my $error = $@;
151                    my $o = Frey->new;
152                    $o->{request_url} = $self->request_url; # sigh, this is dynamic languge, right?
153                    Frey::Web->meta->apply( $o );
154                    $html = $o->page( body => $self->error( $error, undef ) );
155          }          }
156    
157          return $self->page( title => $class, body => $html );          warn $self->class, " produced ", length($html), " bytes of ", $self->content_type;
158    
159            return $html;
160  }  }
161    
162  1;  1;

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

  ViewVC Help
Powered by ViewVC 1.1.26