/[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 358 by dpavlin, Sun Nov 16 16:36:53 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::PPI';
5  with 'Frey::Web';  with 'Frey::Web';
6  with 'Frey::Config';  with 'Frey::Config';
7    with 'Frey::Escape';
8    
9    use Data::Dump qw/dump/;
10    use Frey::Dumper;
11    
12  =head1 NAME  =head1 NAME
13    
# Line 11  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<html> or C<markup> method on the.  will try to invoke C<data>, and C<markup> method on the.
20    
21  =cut  =cut
22    
23    use Moose::Util::TypeConstraints;
24    
25    enum 'Runnable' => qw/data markup sponge/;
26    
27    sub runnable { qw/data markup sponge/ }
28    
29  has 'class' => (  has 'class' => (
30          is => 'rw',          is => 'rw',
31          isa => 'Str',          isa => 'Str',
32          required => 1,          required => 1,
33  );  );
34    
35  use Data::Dump qw/dump/;  has 'params' => (
36            is => 'rw',
37            isa => 'HashRef',
38            default => sub { {} },
39    );
40    
41  sub request {  has 'run' => (
42          my ( $self, $req ) = @_;          is => 'rw',
43            isa => 'Runnable',
44            default => 'markup',
45    );
46    
47    sub html {
48            my ( $self ) = @_;
49    
         my %params = $req->params;  
50          my $class = $self->class;          my $class = $self->class;
51    
52            $self->load_class( $class );
53    
54          my @required =          my @required =
55                  grep {                  grep {
56                          defined $_ && !defined( $params{$_} )                          defined $_ && $_->can('name') && !defined( $self->params->{ $_->name } )
57                  }                  }
58                  map {                  map {
59                          my $attr = $class->meta->get_attribute($_);                          my $attr = $class->meta->get_attribute($_);
60                          $attr->is_required && $_                          $attr->is_required && $attr;
61                  } $class->meta->get_attribute_list;                  } $class->meta->get_attribute_list;
62    
63                  warn "## required = ",dump( @required );          warn "## required = ",dump( map { $_->name } @required ), " for $class";
                 warn "## params = ",dump( %params );  
64    
65          my $html;          my $html;
66            my $values = {};
67            $values = $self->config($class);
68            warn "# $class config = ",dump( $values );
69    
70          if ( @required ) {          if ( @required ) {
71                  $html = qq|<h1>Required params for $class</h1><form method="post">|;                  $html = qq|<h1>$class params</h1><form method="post">|;
72                  foreach my $name ( @required ) {  
73                    my $a;
74                    my @attrs = map {  $a->{$_}++; $_ } $self->attribute_order;
75                    push @attrs, $_ foreach grep { ! $a->{$_} } map { $_->name } @required;
76                    warn "# attrs = ",dump( @attrs );
77    
78                    foreach my $name ( @attrs ) {
79                            my $attr = $class->meta->get_attribute( $name );
80                          my $type = $name =~ m/^pass/ ? 'password' : 'text';                          my $type = $name =~ m/^pass/ ? 'password' : 'text';
81                          my $value = $self->config($class)->{$name};                          my $value = '';
82                          $html .= qq|<label for="$name">$name</label><input type="$type" name="$name" value="$value">|;                          my $value_html = '';
83                            if ( ref($values) eq 'HASH' ) {
84                                    $value = $values->{$name};
85                            } elsif ( ref($values) eq 'ARRAY' ) {
86                                    $value_html = qq|<select name="$name">| . join("\n",
87                                            map {
88                                                    my $v = $_->{$name};
89                                                    qq|<option value="$v">$v</option>|
90                                            } @$values
91                                    ) . qq|</select>|;
92                            } elsif ( $attr->has_type_constraint && $attr->type_constraint->can('values') ) {
93                                    $value_html = qq|<select name="$name">| . join("\n",
94                                            map { qq|<option value="$_">$_</option>| } @{ $attr->type_constraint->values }
95                                    ) . qq|</select>|;
96                            } elsif ( $attr->has_default ) {
97                                    $value = $attr->default( $name );
98                            }
99                            $value_html = qq|<input type="$type" name="$name" value="$value">| unless $value_html;
100    
101    #warn "# required $name ", $class->meta->get_attribute( $name )->dump( 2 );
102                            $html .= qq|<label for="$name">$name</label>| . $value_html;
103                  }                  }
104                  $html .= qq|<input type="submit" value="Run $class"></form>|;                  $html .= qq|<input type="submit" value="Run $class"></form>|;
105          } else {          } else {
106                  my $o = $class->new( %params );                  eval {
107                  $o->depends if $o->can('depends');                          my $o;
108                  if ( $o->can('request') ) {                          $o = $class->new( %{ $self->params } );
109                          warn "## turning over to $o->request";                          $o->depends if $o->can('depends');
110                          $o->request( $req );  
111                  } elsif ( $o->can('markup') ) {                          if ( $self->run eq 'markup' ) {
112                          warn "## using $o->markup";                                  warn "## using ",ref($o), "->markup";
113                          $html = $o->markup;                                  $html = $o->markup;
114                          warn ">>> markup $class ",length( $html ), " bytes\n";                                  warn ">>> markup $class ",length( $html ), " bytes\n";
115                  } else {                          } elsif ( $self->run eq 'sponge' ) {
116                          $html = "IGNORE: $class ", $o->dump;                                  my $data = $o->sponge;
117                          warn $html;                                  confess "invalid data from sponge = ", dump( $data ) unless ref($data) eq 'HASH';
118                  }                                  $html .= "<strong>" . $#{ $data->{rows} } . "</strong> rows from <code>$class->new" . dump( $self->params ) . "->sponge</code>";
119                                    $html .= '<table>';
120                                    $html .= '<tr><th>' . join('</th><th>', @{$data->{NAME}} ) . '</th></tr>';
121                                    $html .= '<tr><td>' . join('</td><td>', @$_ ) . '</td></tr>' foreach @{ $data->{rows} };
122                                    $html .= '</table>';
123                            } elsif ( $self->run eq 'data' ) {
124                                    my $data = $o->data;
125                                    $html .= Frey::Dumper->new( data => $data )->markup;
126                                    $html .= '<hr/><code>' . $self->html_dump( $data ) . '</code>';
127                            } else {
128                                    $html = $self->error( "IGNORE: $class ", $o->dump );
129                            }
130                    };
131    
132                    $html .= $self->error( $@ ) if $@;
133          }          }
134    
135          $req->print( $self->page( title => $class, body => $html ) );          return $self->page( %$html ) if ref($html) eq 'HASH';
136            return $self->page( title => $class, body => $html );
137  }  }
138    
139  1;  1;

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

  ViewVC Help
Powered by ViewVC 1.1.26