/[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 222 by dpavlin, Fri Oct 31 23:17:56 2008 UTC revision 443 by dpavlin, Wed Nov 19 02:14:48 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';
6  with 'Frey::Config';  with 'Frey::Escape';
7    with 'Frey::Session';
8    
9    use Data::Dump qw/dump/;
10    use Frey::Dumper;
11    use JSON;
12    use YAML;
13    
14  =head1 NAME  =head1 NAME
15    
# Line 11  Frey::Run - display required form field Line 18  Frey::Run - display required form field
18  =head1 DESCRIPTION  =head1 DESCRIPTION
19    
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<html> or 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;
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',
39          isa => 'Str',          isa => 'Str',
40          required => 1,          required => 1,
41  );  );
42    
43  use Data::Dump qw/dump/;  has 'params' => (
44            is => 'rw',
45            isa => 'HashRef',
46            default => sub { {} },
47    );
48    
49  sub request {  has 'run' => (
50          my ( $self, $req ) = @_;          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          my %params = $req->params;  sub html {
62          my $class = $self->class;          my ( $self ) = @_;
63    
64          my @required =          my ($html,$body,$data);
65                  grep {          eval {
66                          defined $_ && !defined( $params{$_} )                  my $class = $self->class;
67                  }                  $self->load_class( $class );
68                  map {  
69                          my $attr = $class->meta->get_attribute($_);                  if ( $body = $self->params_form ) {
70                          $attr->is_required && $_                          warn "got required params form for $class ", $self->run, " format: ", $self->format;
                 } $class->meta->get_attribute_list;  
   
                 warn "## required = ",dump( @required );  
                 warn "## params = ",dump( %params );  
   
         my $html;  
   
         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 = $self->config($class)->{$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 $o->markup";  
                         $html = $o->markup;  
                         warn ">>> markup $class ",length( $html ), " bytes\n";  
71                  } else {                  } else {
                         $html = "IGNORE: $class ", $o->dump;  
                         warn $html;  
                 }  
         }  
72    
73          $req->print( $self->page( title => $class, body => $html ) );                          $self->usage->{ $class }++;
74    
75                            my $o;
76                            my ( $meta, $is_role, $instance ) = $self->class_meta( $class );
77                            if ( $is_role ) {
78                                    $o = $instance;
79                            } else {
80                                    $o = $class->new( %{ $self->params } );
81                            }
82    
83                            $o->depends if $o->can('depends');
84    
85                            push @{ $self->status }, { qq|<a target="editor" href="/editor+$class+1">$class</a>| => $self->params };
86    
87                            if ( $self->run eq 'markup' ) {
88                                    warn "## using ",ref($o), "->markup";
89                                    if ( $o->can('page') ) {
90                                            #$html = $o->page;
91                                            $body = $o->markup unless $html;
92                                    } else {
93                                            $body = $o->markup;
94                                    }
95    
96                                    warn ">>> markup $class ",length( $html || $body ), " ", $html ? 'html' : 'body', " bytes";
97                            } elsif ( $self->run eq 'sponge' ) {
98                                    $data = $o->sponge;
99                                    confess "invalid data from sponge = ", dump( $data ) unless ref($data) eq 'HASH';
100                                    if ( $self->format eq 'html' ) {
101                                            my $rows = $#{ $data->{rows} } + 1;
102                                            $rows ||= 'no';
103                                            $body .= "<strong>$rows</strong> rows from <code>$class->new" . dump( $self->params ) . "->sponge</code>";
104                                            $body .= '<table>';
105                                            $body .= '<tr><th>' . join('</th><th>', @{$data->{NAME}} ) . '</th></tr>';
106                                            $body .= '<tr><td>' . join('</td><td>', @$_ ) . '</td></tr>' foreach @{ $data->{rows} };
107                                            $body .= '</table>';
108                                    }
109                            } elsif ( $self->run eq 'data' ) {
110                                    $data = $o->data;
111                            } else {
112                                    $body = $self->error( "IGNORE: $class ", $o->dump );
113                            }
114    
115                            if ( defined $data ) {
116                                    $html .= to_json( $data ) if $self->format =~ m{js(on)?};
117                                    $html .= Dump( $data )    if $self->format =~ m{ya?ml};
118                                    push @{ $self->status }, { 'data' => $data };
119                            }
120                            if ( ! $html ) {
121                                    $body .= Frey::Dumper->new( data => $data )->markup;
122                            }
123    
124                            # override our status with one from object
125                            eval {
126                                    $self->status( $o->status );
127                            };
128                            warn "can't override status: $@" if $@;
129                    };
130    
131    
132                    if ( ref($body) eq 'HASH' ) {
133                            $html = $self->page( %$body );
134                    } elsif ( $body && ! $html ) {
135                            $html = $self->page( title => $self->class . ' run', body => $body );
136                    };
137            };
138    
139            $html = $self->page( title => $self->class, body => $self->error( $@ ) ) if $@;
140    
141            return $html;
142  }  }
143    
144  1;  1;

Legend:
Removed from v.222  
changed lines
  Added in v.443

  ViewVC Help
Powered by ViewVC 1.1.26