/[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 289 by dpavlin, Wed Nov 5 08:21:00 2008 UTC revision 591 by dpavlin, Fri Nov 28 16:39:37 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  with 'Frey::Web';  extends 'Frey::Action';
5  with 'Frey::Config';  with 'Frey::Session';
6  with 'Frey::Escape';  
7    use Data::Dump qw/dump/;
8    use Frey::View::Dumper;
9    use JSON;
10    use YAML;
11    
12  =head1 NAME  =head1 NAME
13    
# Line 12  Frey::Run - display required form field Line 16  Frey::Run - display required form field
16  =head1 DESCRIPTION  =head1 DESCRIPTION
17    
18  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
19  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.
20    
21    =head1 SEE ALSO
22    
23    L<Frey::Action> which creates form for params
24    
25  =cut  =cut
26    
27  sub execute { qw/data markup/ }  use Moose::Util::TypeConstraints;
28    
29    subtype 'Runnable'
30            => as 'Str',
31            => where sub { m{^as_} || m{_as_} };
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 30  has 'params' => ( Line 45  has 'params' => (
45          default => sub { {} },          default => sub { {} },
46  );  );
47    
48  use Data::Dump qw/dump/;  has 'run' => (
49            is => 'rw',
50            isa => 'Runnable',
51            default => 'as_markup',
52    );
53    
54    has 'format' => (
55            is => 'rw',
56            isa => 'Formats',
57            default => 'html',
58    );
59    
60  sub html {  sub html {
61          my ( $self ) = @_;          my ( $self ) = @_;
62    
63          my $class = $self->class;          my ($html,$body,$data);
64            eval {
65                    my $class = $self->class;
66                    $self->load_class( $class );
67    
68                    if ( my $form = $self->params_form ) {
69                            $html = $self->page( body => $form );
70                            warn "got required params form for $class ", $self->run, " format: ", $self->format;
71                    } else {
72    
73                            $self->usage->{ $class }++;
74    
75          my @required =  =begin remove
76                  grep {                          my $o;
77                          defined $_ && $_->can('name') && !defined( $self->params->{ $_->name } )                          my ( $meta, $is_role, $instance ) = $self->class_meta( $class );
78                  }                          if ( $is_role ) {
79                  map {                                  $o = $instance;
80                          my $attr = $class->meta->get_attribute($_);                                  if ( $o->can('add_status') ) {
81                          $attr->is_required && $attr;                                          $self->TODO("missing add_status in $o");
82                  } $class->meta->get_attribute_list;                                          Frey::Web->meta->apply( $o );
83                                            warn "# apply Frey::Web to $class instance $o";
84          warn "## required = ",dump( map { $_->name } @required ), " for $class";                                  }
85                            } else {
86          my $html;                                  $o = $self->new_frey_class( $class, $self->params );
         my $values = {};  
         $values = $self->config($class) if $self->can('config');  
   
         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>};  
87                          }                          }
88                          warn ">>> markup $class ",length( $html ), " bytes\n";  =cut
89                  } elsif ( $o->can('data') ) {  
90                          $html = '<code>' . $self->html_escape( dump( $o->data ) ) . '</code>';                          my $o = $self->new_frey_class( $class, $self->params );
91                  } else {                          $o->depends if $o->can('depends');
92                          $html = "IGNORE: $class ", $o->dump;  
93                          warn $html;                          if ( $self->run =~ m{as_markup} ) {
94                  }                                  $html = $o->page( run => $self->run );
95                            } elsif ( $self->run =~ m{as_sponge} ) {
96                                    $data = $o->as_sponge;
97                                    confess "invalid data from sponge = ", dump( $data ) unless ref($data) eq 'HASH';
98                                    if ( $self->format eq 'html' ) {
99                                            my $rows = $#{ $data->{rows} } + 1;
100                                            $rows ||= 'no';
101                                            $body .= "<strong>$rows</strong> rows from <code>$class->new" . dump( $self->params ) . "->as_sponge</code>";
102                                            $body .= '<table>';
103                                            $body .= '<tr><th>' . join('</th><th>', @{$data->{NAME}} ) . '</th></tr>';
104                                            $body .= '<tr><td>' . join('</td><td>', @$_ ) . '</td></tr>' foreach @{ $data->{rows} };
105                                            $body .= '</table>';
106                                    }
107                            } elsif ( $self->run =~ m{as_data} ) {
108                                    $data = $o->{$self->run}();
109                                    warn "no data from ", $self->run;
110                                    $data ||= $o->as_data();
111                                    confess "no data for $class->" . $self->run . " from " . $self->html_dump( $data ) unless $data;
112                                    $self->add_status( { $self->run => $data } );
113                            } else {
114                                    $body = $self->error( "IGNORE: $class ", $o->dump );
115                            }
116    
117                            if ( defined $data ) {
118                                    $html .= to_json( $data ) if $self->format =~ m{js(on)?};
119                                    $html .= Dump( $data )    if $self->format =~ m{ya?ml};
120                            }
121                            if ( ! $html ) {
122                                    $body  = Frey::View::Dumper->new( data => $body )->as_markup if ref $body;
123                                    $body .= Frey::View::Dumper->new( data => $data )->as_markup if defined $data;
124                            }
125    
126                            $self->title( $class );
127    
128                            $html = $o->page( body => $body ) if $body && !$html;
129            
130                            confess "no html output for $class ", $o->dump unless defined $html;
131                    };
132    
133            };
134    
135            $self->status_parts;
136    
137            if ( $@ ) {
138                    my $o = Frey->new;
139                    Frey::Web->meta->apply( $o );
140                    $html = $o->page( body => $self->error( $@ ) );
141          }          }
142    
143          return $self->page( title => $class, body => $html );          warn $self->class, " produced ", length($html), " bytes";
144    
145            return $html;
146  }  }
147    
148  1;  1;

Legend:
Removed from v.289  
changed lines
  Added in v.591

  ViewVC Help
Powered by ViewVC 1.1.26