/[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 229 by dpavlin, Sat Nov 1 13:17:45 2008 UTC revision 423 by dpavlin, Tue Nov 18 19:50:45 2008 UTC
# Line 1  Line 1 
1  package Frey::Run;  package Frey::Run;
2  use Moose;  use Moose;
3  extends 'Frey';  #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    
8    use Data::Dump qw/dump/;
9    use Frey::Dumper;
10    use JSON;
11    use YAML;
12    
13  =head1 NAME  =head1 NAME
14    
15  Frey::Run - display required form field for Class and run it  Frey::Run - display required form field for Class and run it
# Line 12  Frey::Run - display required form field Line 17  Frey::Run - display required form field
17  =head1 DESCRIPTION  =head1 DESCRIPTION
18    
19  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
20  will try to invoke C<data>, C<html> or C<markup> method on the.  will try to invoke C<data>, and C<markup> method on the.
21    
22    =head1 SEE ALSO
23    
24    L<Frey::Action> which creates form for params
25    
26  =cut  =cut
27    
28  sub execute { qw/data markup request/ }  use Moose::Util::TypeConstraints;
29    
30    sub runnable { qw/data data.js markup sponge/ }
31    enum 'Runnable' => runnable;
32    
33    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 24  has 'class' => ( Line 39  has 'class' => (
39          required => 1,          required => 1,
40  );  );
41    
42  use Data::Dump qw/dump/;  has 'params' => (
43            is => 'rw',
44            isa => 'HashRef',
45            default => sub { {} },
46    );
47    
48  sub request {  has 'run' => (
49          my ( $self, $req ) = @_;          is => 'rw',
50            isa => 'Runnable',
51            default => 'markup',
52    );
53    
54    has 'format' => (
55            is => 'rw',
56            isa => 'Formats',
57            default => 'html',
58    );
59    
60    sub html {
61            my ( $self ) = @_;
62    
63          my %params = $req->params;          my ($html,$body,$data);
64          my $class = $self->class;          eval {
65                    my $class = $self->class;
66                    $self->load_class( $class );
67    
68          my @required =                  if ( $body = $self->params_form ) {
69                  grep {                          warn "got required params form for $class ", $self->run, " format: ", $self->format;
                         defined $_ && !defined( $params{$_} )  
                 }  
                 map {  
                         my $attr = $class->meta->get_attribute($_);  
                         $attr->is_required && $_  
                 } $class->meta->get_attribute_list;  
   
                 warn "## required = ",dump( @required );  
                 warn "## params = ",dump( %params );  
   
         my $html;  
         my $values = $self->config($class);  
         $values = {} if $@;  
   
         if ( @required ) {  
                 $html = qq|<h1>Required params for $class</h1><form method="post">|;  
                 foreach my $name ( @required ) {  
                         my $type = $name =~ m/^pass/ ? 'password' : 'text';  
                         my $value = $values ? $values->{$name} : '';  
                         $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( %params );  
                 $o->depends if $o->can('depends');  
                 if ( $o->can('request') ) {  
                         warn "## turning over to $o->request";  
                         $o->request( $req );  
                 } elsif ( $o->can('markup') ) {  
                         warn "## using ",ref($o), "->markup";  
                         $html = $o->markup;  
                         warn ">>> markup $class ",length( $html ), " bytes\n";  
                 } elsif ( $o->can('data') ) {  
                         $html = '<code>' . $self->html_escape( dump( $o->data ) ) . '</code>';  
70                  } else {                  } else {
                         $html = "IGNORE: $class ", $o->dump;  
                         warn $html;  
                 }  
         }  
71    
72          $req->print( $self->page( title => $class, body => $html ) );                          my $o = $class->new( %{ $self->params } );
73                            $o->depends if $o->can('depends');
74    
75                            push @{ $self->status }, { qq|<a target="editor" href="/editor+$class+1">$class</a>| => $self->params };
76    
77                            if ( $self->run eq 'markup' ) {
78                                    warn "## using ",ref($o), "->markup";
79                                    if ( $o->can('page') ) {
80                                            #$html = $o->page;
81                                            $body = $o->markup unless $html;
82                                    } else {
83                                            $body = $o->markup;
84                                    }
85    
86                                    warn ">>> markup $class ",length( $html || $body ), " ", $html ? 'html' : 'body', " bytes";
87                            } elsif ( $self->run eq 'sponge' ) {
88                                    $data = $o->sponge;
89                                    confess "invalid data from sponge = ", dump( $data ) unless ref($data) eq 'HASH';
90                                    if ( $self->format eq 'html' ) {
91                                            my $rows = $#{ $data->{rows} } + 1;
92                                            $rows ||= 'no';
93                                            $body .= "<strong>$rows</strong> rows from <code>$class->new" . dump( $self->params ) . "->sponge</code>";
94                                            $body .= '<table>';
95                                            $body .= '<tr><th>' . join('</th><th>', @{$data->{NAME}} ) . '</th></tr>';
96                                            $body .= '<tr><td>' . join('</td><td>', @$_ ) . '</td></tr>' foreach @{ $data->{rows} };
97                                            $body .= '</table>';
98                                    }
99                            } elsif ( $self->run eq 'data' ) {
100                                    $data = $o->data;
101                            } else {
102                                    $body = $self->error( "IGNORE: $class ", $o->dump );
103                            }
104    
105                            if ( defined $data ) {
106                                    $html .= to_json( $data ) if $self->format =~ m{js(on)?};
107                                    $html .= Dump( $data )    if $self->format =~ m{ya?ml};
108                                    push @{ $self->status }, { 'data' => $data };
109                            }
110                            if ( ! $html ) {
111                                    $body .= Frey::Dumper->new( data => $data )->markup;
112                            }
113    
114                            # override our status with one from object
115                            eval {
116                                    $self->status( $o->status );
117                            };
118                            warn "can't override status: $@" if $@;
119                    };
120    
121    
122                    if ( ref($body) eq 'HASH' ) {
123                            $html = $self->page( %$body );
124                    } elsif ( $body && ! $html ) {
125                            $html = $self->page( title => $self->class . ' run', body => $body );
126                    };
127            };
128    
129            $html = $self->page( title => $self->class, body => dump($html) . $self->error( $@ ) ) if $@;
130    
131            return $html;
132  }  }
133    
134  1;  1;

Legend:
Removed from v.229  
changed lines
  Added in v.423

  ViewVC Help
Powered by ViewVC 1.1.26