/[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 327 by dpavlin, Thu Nov 6 20:56:44 2008 UTC revision 431 by dpavlin, Wed Nov 19 00:40:03 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::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::Dumper;
11    use JSON;
12    use YAML;
13    
14  =head1 NAME  =head1 NAME
15    
# Line 17  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/ }  use Moose::Util::TypeConstraints;
30    
31    sub runnable { qw/data data.js markup sponge/ }
32    enum 'Runnable' => runnable;
33    
34    sub formats_available { qw/html js json yaml yml/ }
35    enum 'Formats' => formats_available;
36    
37  has 'class' => (  has 'class' => (
38          is => 'rw',          is => 'rw',
# Line 33  has 'params' => ( Line 46  has 'params' => (
46          default => sub { {} },          default => sub { {} },
47  );  );
48    
49    has 'run' => (
50            is => 'rw',
51            isa => 'Runnable',
52            default => 'markup',
53    );
54    
55    has 'format' => (
56            is => 'rw',
57            isa => 'Formats',
58            default => 'html',
59    );
60    
61  sub html {  sub html {
62          my ( $self ) = @_;          my ( $self ) = @_;
63    
64          my $class = $self->class;          my ($html,$body,$data);
65            eval {
66                    my $class = $self->class;
67                    $self->load_class( $class );
68    
69                    if ( $body = $self->params_form ) {
70                            warn "got required params form for $class ", $self->run, " format: ", $self->format;
71                    } else {
72    
73          $self->load_class( $class );                          $self->usage->{ $class }++;
74    
75          my @required =                          my $o;
76                  grep {                          eval { $o = $class->new( %{ $self->params } ) };
                         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>Required params for $class</h1><form method="post">|;  
                 foreach my $attr ( @required ) {  
                         my $name = $attr->name;  
                         my $type = $name =~ m/^pass/ ? 'password' : 'text';  
                         my $value =  
                                 $values ? $values->{$name} :  
                                 $attr->has_default ? $attr->default( $name ) :  
                                 '';  
 #warn "# required $name ", $class->meta->get_attribute( $name )->dump( 2 );  
                         $html .= qq|<label for="$name">$name</label><input type="$type" name="$name" value="$value">|;  
                 }  
                 $html .= qq|<input type="submit" value="Run $class"></form>|;  
         } 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 };  
77                          if ( $@ ) {                          if ( $@ ) {
78                                  warn $@;                                  warn "can't call $class->new: $@" if $@;
79                                  $html .= qq{<code>$@</code>};                                  my ( $meta, $is_role, $instance ) = $self->class_meta( $class );
80                                    $o = $instance if $is_role;
81                          }                          }
82                          warn ">>> markup $class ",length( $html ), " bytes\n";                          confess "can't create class instance for $class" unless $o;
83                  } elsif ( $o->can('data') ) {  
84                          my $data = $o->data;                          $o->depends if $o->can('depends');
85                          $html .= Frey::Dumper->new( data => $data )->markup;  
86                          $html .= '<hr/><code>' . $self->html_dump( $data ) . '</code>';                          push @{ $self->status }, { qq|<a target="editor" href="/editor+$class+1">$class</a>| => $self->params };
87                  } else {  
88                          $html = "IGNORE: $class ", $o->dump;                          if ( $self->run eq 'markup' ) {
89                          warn $html;                                  warn "## using ",ref($o), "->markup";
90                  }                                  if ( $o->can('page') ) {
91          }                                          #$html = $o->page;
92                                            $body = $o->markup unless $html;
93                                    } else {
94                                            $body = $o->markup;
95                                    }
96    
97                                    warn ">>> markup $class ",length( $html || $body ), " ", $html ? 'html' : 'body', " bytes";
98                            } elsif ( $self->run eq 'sponge' ) {
99                                    $data = $o->sponge;
100                                    confess "invalid data from sponge = ", dump( $data ) unless ref($data) eq 'HASH';
101                                    if ( $self->format eq 'html' ) {
102                                            my $rows = $#{ $data->{rows} } + 1;
103                                            $rows ||= 'no';
104                                            $body .= "<strong>$rows</strong> rows from <code>$class->new" . dump( $self->params ) . "->sponge</code>";
105                                            $body .= '<table>';
106                                            $body .= '<tr><th>' . join('</th><th>', @{$data->{NAME}} ) . '</th></tr>';
107                                            $body .= '<tr><td>' . join('</td><td>', @$_ ) . '</td></tr>' foreach @{ $data->{rows} };
108                                            $body .= '</table>';
109                                    }
110                            } elsif ( $self->run eq 'data' ) {
111                                    $data = $o->data;
112                            } else {
113                                    $body = $self->error( "IGNORE: $class ", $o->dump );
114                            }
115    
116                            if ( defined $data ) {
117                                    $html .= to_json( $data ) if $self->format =~ m{js(on)?};
118                                    $html .= Dump( $data )    if $self->format =~ m{ya?ml};
119                                    push @{ $self->status }, { 'data' => $data };
120                            }
121                            if ( ! $html ) {
122                                    $body .= Frey::Dumper->new( data => $data )->markup;
123                            }
124    
125                            # override our status with one from object
126                            eval {
127                                    $self->status( $o->status );
128                            };
129                            warn "can't override status: $@" if $@;
130                    };
131    
132    
133                    if ( ref($body) eq 'HASH' ) {
134                            $html = $self->page( %$body );
135                    } elsif ( $body && ! $html ) {
136                            $html = $self->page( title => $self->class . ' run', body => $body );
137                    };
138            };
139    
140            $html = $self->page( title => $self->class, body => dump($html) . $self->error( $@ ) ) if $@;
141    
142          return $self->page( title => $class, body => $html );          return $html;
143  }  }
144    
145  1;  1;

Legend:
Removed from v.327  
changed lines
  Added in v.431

  ViewVC Help
Powered by ViewVC 1.1.26