X-Git-Url: https://git.decadent.org.uk/gitweb/?a=blobdiff_plain;f=lib%2FMaypole.pm;h=20a3c0e02f14c8593e824fdd9c59ce310a3a9320;hb=cdf684b24a154500e5c05a49be8b5c7bae6a08a8;hp=9a86489b8127d7cbb0914409d88ca0a415948415;hpb=74800a709376d0ce878cabd9db6b3578c002606c;p=maypole.git diff --git a/lib/Maypole.pm b/lib/Maypole.pm index 9a86489..20a3c0e 100644 --- a/lib/Maypole.pm +++ b/lib/Maypole.pm @@ -2,16 +2,20 @@ package Maypole; use base qw(Class::Accessor Class::Data::Inheritable); use attributes (); use UNIVERSAL::require; -use Apache::Constants ":common"; use strict; use warnings; -our $VERSION = "1.1"; +our $VERSION = "1.3"; __PACKAGE__->mk_classdata($_) for qw( config init_done view_object ); __PACKAGE__->mk_accessors ( qw( ar params query objects model_class args action template )); __PACKAGE__->config({}); __PACKAGE__->init_done(0); +# Ape Apache::Constants interface +use constant OK => 0; +use constant DECLINED => -1; + +sub debug { 0 } sub setup { my $calling_class = shift; @@ -24,6 +28,7 @@ sub setup { my $config = $calling_class->config; $config->{model} ||= "Maypole::Model::CDBI"; $config->{model}->require; + die "Couldn't load the model class $config->{model}: $@" if $@; $config->{model}->setup_database($config, $calling_class, @_); for my $subclass (@{$config->{classes}}) { no strict 'refs'; @@ -38,6 +43,7 @@ sub init { my $config = $class->config; $config->{view} ||= "Maypole::View::TT"; $config->{view}->require; + die "Couldn't load the view class $config->{view}: $@" if $@; $config->{display_tables} ||= [ @{$class->config->{tables}} ]; $class->view_object($class->config->{view}->new); $class->init_done(1); @@ -56,6 +62,10 @@ sub handler { my $status = $r->is_applicable; if ($status == OK) { $status = $r->call_authenticate; + if ($r->debug and $status != OK and $status != DECLINED) { + $r->view_object->error($r, + "Got unexpected status $status from calling authentication"); + } return $status unless $status == OK; $r->additional_data(); @@ -67,25 +77,31 @@ sub handler { $r->{path} =~ s{/}{}; # De-absolutify $r->template($r->{path}); } - return $r->view_object->process($r); + $status = OK; + if (!$r->{output}) { # You might want to do it yourself + $status = $r->view_object->process($r); + } + $r->send_output; + return $status; } sub is_applicable { my $self = shift; my $config = $self->config; $config->{ok_tables} = {map {$_ => 1} @{$config->{display_tables}}}; - #warn "We don't have that table ($self->{table})" - # unless $config->{ok_tables}{$self->{table}}; + warn "We don't have that table ($self->{table})" + if $self->debug and not $config->{ok_tables}{$self->{table}}; return DECLINED() unless exists $config->{ok_tables}{$self->{table}}; # Does the action method exist? my $cv = $self->model_class->can($self->{action}); - #warn "We don't have that action ($self->{action})" unless $cv; + warn "We don't have that action ($self->{action})" + if $self->debug and not $cv; return DECLINED() unless $cv; # Is it exported? $self->{method_attribs} = join " ", attributes::get($cv); - do { # warn "$self->{action} not exported"; + do { warn "$self->{action} not exported" if $self->debug; return DECLINED() } unless $self->{method_attribs} =~ /\bExported\b/i; return OK(); @@ -194,7 +210,7 @@ subclass the model class, and configure your class slightly differently: Then your top-level application package should change the model class: (Before calling C) - ProductDatabase->config->{model_class} = "ProductDatabase::Model"; + ProductDatabase->config->{model} = "ProductDatabase::Model"; (The C<:Exported> attribute means that the method can be called via the URL C/supersearch/...>.) @@ -219,14 +235,23 @@ class which does not specify how to communicate with the outside world. The most popular subclass of Maypole is L, which interfaces the Maypole framework to Apache mod_perl. -If you are implementing Maypole subclasses, you need to provide at least -the C and C methods. See the +If you are implementing Maypole subclasses, you need to provide at least +the C and C methods. You may also want to +provide C and C. See the L documentation for what these are expected to do. =cut -sub get_request { die "Do not use Maypole directly; use Apache::MVC or similar" } +sub get_template_root { "." } +sub get_request { } sub parse_location { die "Do not use Maypole directly; use Apache::MVC or similar" } +sub send_output{ die "Do not use Maypole directly; use Apache::MVC or similar" } + +=head1 SEE ALSO + +There's more documentation, examples, and a wiki at the Maypole web site: + +http://maypole.simon-cozens.org/ =head1 AUTHOR