use strict;
use warnings;
-our $VERSION = "0.3";
+use CGI::Simple;
+
+our $VERSION = '2.05';
sub run {
my $self = shift;
}
sub get_request {
- require CGI::Simple;
shift->{cgi} = CGI::Simple->new();
}
$self->{path} = $self->{cgi}->url( -absolute => 1, -path_info => 1 );
my $loc = $self->{cgi}->url( -absolute => 1 );
no warnings 'uninitialized';
+ $self->{path} .= '/' if $self->{path} eq $loc;
$self->{path} =~ s/^($loc)?\///;
- $self->rewrite_path;
$self->parse_path;
$self->parse_args;
}
my (%vars) = $self->{cgi}->Vars;
while ( my ( $key, $value ) = each %vars ) {
my @values = split "\0", $value;
- $vars{$key} = @values == 1 ? $values[0] : \@values;
+ $vars{$key} = @values <= 1 ? $values[0] : \@values;
}
$self->{params} = {%vars};
$self->{query} = {%vars};
print $r->{cgi}->header(
-type => $r->{content_type},
-charset => $r->{document_encoding},
- -content_length => length $r->{output},
+ -content_length => do { use bytes; length $r->{output} },
);
print $r->{output};
}
=head1 SYNOPSIS
package BeerDB;
- use base 'CGI::Maypole;
+ use base 'CGI::Maypole';
BeerDB->setup("dbi:mysql:beerdb");
BeerDB->config->uri_base("http://your.site/cgi-bin/beer.cgi/");
BeerDB->config->display_tables([qw[beer brewery pub style]]);
+ BeerDB->config->template_root("/var/www/beerdb/");
# Now set up your database:
# has-a relationships
# untaint columns
1;
## example beer.cgi:
-
+
#!/usr/bin/perl -w
use strict;
use BeerDB;
BeerDB->run();
+Now to access the beer database, type this URL into your browser:
+http://your.site/cgi-bin/beer.cgi/frontpage
+
=head1 DESCRIPTION
This is a handler for Maypole which will use the CGI instead of Apache's
C<mod_perl> 1.x. This handler can also be used for Apache 2.0.
+=head1 METHODS
+
+=over
+
+=item run
+
+Call this from your CGI script to start the Maypole application.
+
+=back
+
+=head1 Implementation
+
+This class overrides a set of methods in the base Maypole class to provide it's
+functionality. See L<Maypole> for these:
+
+=over
+
+=item get_request
+
+=item get_template_root
+
+=item parse_args
+
+=item parse_location
+
+=item send_output
+
+=back
+
=head1 AUTHORS
Dave Ranney C<dave@sialia.com>