Skip to content

Commit

Permalink
Bug 1272673 - make app.psgi runnable
Browse files Browse the repository at this point in the history
  • Loading branch information
dylanwh committed Mar 26, 2017
1 parent dfb6888 commit c636314
Show file tree
Hide file tree
Showing 2 changed files with 38 additions and 12 deletions.
2 changes: 1 addition & 1 deletion README.rst
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ Finally, a webserver can be started by the following:

.. code-block:: bash
perl -Ilocal/lib/perl5 local/bin/plackup
perl app.psgi
Navigate to http://localhost:5000/ and login with the username and password provided earlier to checksetup.
Remember to set the urlbase on http://localhost:5000/editparams.cgi. "http://localhost:5000" will probably suffice.
Expand Down
48 changes: 37 additions & 11 deletions app.psgi
Original file line number Diff line number Diff line change
Expand Up @@ -12,10 +12,19 @@ use warnings;

use File::Basename;
use File::Spec;

BEGIN {
require lib;
my $dir = dirname(__FILE__);
lib->import($dir, File::Spec->catdir($dir, "lib"), File::Spec->catdir($dir, qw(local lib perl5)));
my $dir = File::Spec->rel2abs( dirname(__FILE__) );
lib->import(
$dir,
File::Spec->catdir( $dir, "lib" ),
File::Spec->catdir( $dir, qw(local lib perl5) )
);

# disable "use lib" from now on
no warnings qw(redefine);
*lib::import = sub { };
}

use Bugzilla::Constants ();
Expand All @@ -37,8 +46,9 @@ use constant STATIC => qw(
skins
);

builder {
my $static_paths = join('|', STATIC);
my $app = builder {
my $static_paths
= join( '|', sort { length $b <=> length $a || $a cmp $b } STATIC );
enable 'Static',
path => qr{^/($static_paths)/},
root => Bugzilla::Constants::bz_locations->{cgi_path};
Expand All @@ -48,10 +58,13 @@ builder {
my $map = Plack::App::URLMap->new;

my @cgis = glob('*.cgi');
my $shutdown_app = Plack::App::WrapCGI->new(script => 'shutdown.cgi')->to_app;
my $shutdown_app
= Plack::App::WrapCGI->new( script => 'shutdown.cgi' )->to_app;

foreach my $cgi_script (@cgis) {
my $app = eval { Plack::App::WrapCGI->new(script => $cgi_script)->to_app };
my $app
= eval { Plack::App::WrapCGI->new( script => $cgi_script )->to_app };

# Some CGI scripts won't compile if not all optional Perl modules are
# installed. That's expected.
if ($@) {
Expand All @@ -61,15 +74,28 @@ builder {

my $wrapper = sub {
my $ret = Bugzilla::init_page();
my $res = ($ret eq '-1' && $cgi_script ne 'editparams.cgi') ? $shutdown_app->(@_) : $app->(@_);
my $res
= ( $ret eq '-1' && $cgi_script ne 'editparams.cgi' )
? $shutdown_app->(@_)
: $app->(@_);
Bugzilla::_cleanup();
return $res;
};

my $base_name = basename($cgi_script);
$map->map('/' => $wrapper) if $cgi_script eq 'index.cgi';
$map->map('/rest' => $wrapper) if $cgi_script eq 'rest.cgi';
$map->map("/$base_name" => $wrapper);
$map->map( '/' => $wrapper ) if $cgi_script eq 'index.cgi';
$map->map( '/rest' => $wrapper ) if $cgi_script eq 'rest.cgi';
$map->map( "/$base_name" => $wrapper );
}
my $app = $map->to_app;
$map->to_app;
};

unless (caller) {
require Plack::Runner;
my $runner = Plack::Runner->new;
$runner->parse_options(@ARGV);
$runner->run($app);
exit 0;
}

return $app;

0 comments on commit c636314

Please sign in to comment.