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

Legend:
Removed from v.348  
changed lines
  Added in v.457

  ViewVC Help
Powered by ViewVC 1.1.26