/[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 324 by dpavlin, Thu Nov 6 18:03:06 2008 UTC revision 570 by dpavlin, Thu Nov 27 22:11:13 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';
6  with 'Frey::Config';  with 'Frey::Session';
7  with 'Frey::Escape';  
8    use Data::Dump qw/dump/;
9    use Frey::View::Dumper;
10    use JSON;
11    use YAML;
12    
13  =head1 NAME  =head1 NAME
14    
# Line 14  Frey::Run - display required form field Line 19  Frey::Run - display required form field
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>, and 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 runnable { qw/data markup/ }  use Moose::Util::TypeConstraints;
29    
30    subtype 'Runnable'
31            => as 'Str',
32            => where sub { m{^as_} };
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 30  has 'params' => ( Line 46  has 'params' => (
46          default => sub { {} },          default => sub { {} },
47  );  );
48    
49  use Data::Dump qw/dump/;  has 'run' => (
50            is => 'rw',
51            isa => 'Runnable',
52            default => 'as_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          $self->load_class( $class );                  my $class = $self->class;
67                    $self->load_class( $class );
68    
69          my @required =                  if ( $body = $self->params_form ) {
70                  grep {                          warn "got required params form for $class ", $self->run, " format: ", $self->format;
                         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 };  
                         if ( $@ ) {  
                                 warn $@;  
                                 $html .= qq{<code>$@</code>};  
                         }  
                         warn ">>> markup $class ",length( $html ), " bytes\n";  
                 } elsif ( $o->can('data') ) {  
                         $html = '<code>' . $self->html_escape( dump( $o->data ) ) . '</code>';  
71                  } else {                  } else {
                         $html = "IGNORE: $class ", $o->dump;  
                         warn $html;  
                 }  
         }  
72    
73          return $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 = $self->new_frey_class( $class, $self->params );
81                            }
82    
83                            $o->depends if $o->can('depends');
84    
85                            my @status;
86    
87                            push @status, { $self->editor( $class ) => $self->params };
88    
89                            if ( $self->run eq 'as_markup' && ! $o->can('page') ) {
90                                    warn "## using ",ref($o), "->as_markup";
91                                    $body = $o->as_markup unless $html;
92                                    warn ">>> markup $class ",length( $body ), " ", $html ? 'html' : 'body', " bytes";
93                            } elsif ( $self->run eq 'as_sponge' ) {
94                                    $data = $o->as_sponge;
95                                    confess "invalid data from sponge = ", dump( $data ) unless ref($data) eq 'HASH';
96                                    if ( $self->format eq 'html' ) {
97                                            my $rows = $#{ $data->{rows} } + 1;
98                                            $rows ||= 'no';
99                                            $body .= "<strong>$rows</strong> rows from <code>$class->new" . dump( $self->params ) . "->as_sponge</code>";
100                                            $body .= '<table>';
101                                            $body .= '<tr><th>' . join('</th><th>', @{$data->{NAME}} ) . '</th></tr>';
102                                            $body .= '<tr><td>' . join('</td><td>', @$_ ) . '</td></tr>' foreach @{ $data->{rows} };
103                                            $body .= '</table>';
104                                    }
105                            } elsif ( $self->run eq 'as_data' ) {
106                                    $data = $o->as_data;
107                            } else {
108                                    $body = $self->error( "IGNORE: $class ", $o->dump );
109                            }
110    
111                            if ( defined $data ) {
112                                    $html .= to_json( $data ) if $self->format =~ m{js(on)?};
113                                    $html .= Dump( $data )    if $self->format =~ m{ya?ml};
114                                    push @status, { 'data' => $data };
115                            }
116                            if ( ! $html ) {
117                                    $body  = Frey::View::Dumper->new( data => $body )->as_markup if ref $body;
118                                    $body .= Frey::View::Dumper->new( data => $data )->as_markup if defined $data;
119                            }
120    
121                            warn "## status from $self ",dump(@status);
122    
123                            if ( $o->can('add_status') ) {
124                                    $o->add_status($_) foreach @status;
125                            }
126    
127                            if ( $self->run eq 'as_markup' && $o->can('page') ) {
128                                    $html = $o->page;
129                                    warn "got ", length($html), " for page from $o",
130                                            $self->debug ? " status " . dump( $o->status ) : '';
131                            } else {
132                                    $self->add_status($_) foreach @status;
133                            }
134    
135                            $self->title( $class );
136                    };
137    
138                    if ( ref($body) eq 'HASH' ) {
139                            $html = $self->page( %$body );
140                            warn "WARNING: old calling convention with HASH which is depriciated but produced ", length($html), " bytes";
141                    } elsif ( $body && ! $html ) {
142                            $html = $self->page( title => $self->class . ' run', body => $body );
143                            warn "wrap body of ",length($body), " in page with ", length($html), " bytes";
144                    };
145            };
146    
147            $self->status_parts;
148    
149            $html = $self->page( title => $self->class, body => $self->error( $@ ) ) if $@;
150    
151            return $html;
152  }  }
153    
154  1;  1;

Legend:
Removed from v.324  
changed lines
  Added in v.570

  ViewVC Help
Powered by ViewVC 1.1.26