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";
__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;
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();
$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();
The most popular subclass of Maypole is L<Apache::MVC>, which interfaces
the Maypole framework to Apache mod_perl.
-If you are implementing Maypole subclasses, you need to provide at least
-the C<get_request> and C<parse_location> methods. See the
+If you are implementing Maypole subclasses, you need to provide at least
+the C<parse_location> and C<send_output> methods. You may also want to
+provide C<get_request> and C<get_template_root>. See the
L<Maypole::Workflow> 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 AUTHOR
sub _tt {
my ($self, $r) = @_;
- my $root = $r->{ar}->document_root . "/". $r->{ar}->location;
+ # This bit sucks.
+ my $root = $r->{config}{template_root} || $r->get_template_root;
Template->new({ INCLUDE_PATH => [
$root,
($r->model_class && File::Spec->catdir($root, $r->model_class->moniker)),
$template->process($r->template, { $self->_args($r) }, \$output)
|| return $self->error($r, $template->error);
- $r->{ar}->content_type("text/html");
- $r->{ar}->headers_out->set("Content-Length" => length $output);
- $r->{ar}->send_http_header;
- $r->{ar}->print($output);
+ $r->{content_type} ||= "text/html";
+ $r->{output} = $output;
return 200;
}
my ($self, $r, $error) = @_;
warn $error;
if ($error =~ /not found$/) { return DECLINED }
- $r->{ar}->send_http_header("text/plain");
- $r->{ar}->print($error);
+ $r->{content_type} = "text/plain";
+ $r->{output} = $error;
+ $r->send_output;
exit;
}