Skip to content

Commit

Permalink
More updates for new Perl/Catalyst version.
Browse files Browse the repository at this point in the history
  • Loading branch information
addrummond committed Jan 1, 2012
1 parent 42f055b commit d304d24
Show file tree
Hide file tree
Showing 6 changed files with 61 additions and 232 deletions.
8 changes: 7 additions & 1 deletion MODULES
Original file line number Diff line number Diff line change
Expand Up @@ -15,4 +15,10 @@ Digest
Archive::Zip
Data::Validate::URI
Log::Handler

Crypt::OpenPGP
Params::Classify
Sub::Identify
Variable::Magic
DateTime
Class::ISA
namespace::clean # latest version of.
13 changes: 3 additions & 10 deletions script/ibexfarm_cgi.pl
100644 → 100755
Original file line number Diff line number Diff line change
@@ -1,14 +1,7 @@
#!/usr/bin/env perl

BEGIN { $ENV{CATALYST_ENGINE} ||= 'CGI' }

use strict;
use warnings;
use FindBin;
use lib "$FindBin::Bin/../lib";
use IbexFarm;

IbexFarm->run;
use Catalyst::ScriptRunner;
Catalyst::ScriptRunner->run('IbexFarm', 'CGI');

1;

Expand All @@ -30,8 +23,8 @@ =head1 AUTHORS
=head1 COPYRIGHT
This library is free software. You can redistribute it and/or modify
it under the same terms as Perl itself.
=cut

49 changes: 12 additions & 37 deletions script/ibexfarm_create.pl
100644 → 100755
Original file line number Diff line number Diff line change
Expand Up @@ -2,37 +2,9 @@

use strict;
use warnings;
use Getopt::Long;
use Pod::Usage;
eval "use Catalyst::Helper;";

if ($@) {
die <<END;
To use the Catalyst development tools including catalyst.pl and the
generated script/myapp_create.pl you need Catalyst::Helper, which is
part of the Catalyst-Devel distribution. Please install this via a
vendor package or by running one of -
perl -MCPAN -e 'install Catalyst::Devel'
perl -MCPANPLUS -e 'install Catalyst::Devel'
END
}

my $force = 0;
my $mech = 0;
my $help = 0;

GetOptions(
'nonew|force' => \$force,
'mech|mechanize' => \$mech,
'help|?' => \$help
);

pod2usage(1) if ( $help || !$ARGV[0] );

my $helper = Catalyst::Helper->new( { '.newfiles' => !$force, mech => $mech } );

pod2usage(1) unless $helper->mk_component( 'IbexFarm', @ARGV );
use Catalyst::ScriptRunner;
Catalyst::ScriptRunner->run('IbexFarm', 'Create');

1;

Expand All @@ -45,25 +17,28 @@ =head1 SYNOPSIS
ibexfarm_create.pl [options] model|view|controller name [helper] [options]
Options:
-force don't create a .new file where a file to be created exists
-mechanize use Test::WWW::Mechanize::Catalyst for tests if available
-help display this help and exits
--force don't create a .new file where a file to be created exists
--mechanize use Test::WWW::Mechanize::Catalyst for tests if available
--help display this help and exits
Examples:
ibexfarm_create.pl controller My::Controller
ibexfarm_create.pl -mechanize controller My::Controller
ibexfarm_create.pl --mechanize controller My::Controller
ibexfarm_create.pl view My::View
ibexfarm_create.pl view MyView TT
ibexfarm_create.pl view TT TT
ibexfarm_create.pl view HTML TT
ibexfarm_create.pl model My::Model
ibexfarm_create.pl model SomeDB DBIC::Schema MyApp::Schema create=dynamic\
dbi:SQLite:/tmp/my.db
ibexfarm_create.pl model AnotherDB DBIC::Schema MyApp::Schema create=static\
dbi:Pg:dbname=foo root 4321
[Loader opts like db_schema, naming] dbi:Pg:dbname=foo root 4321
[connect_info opts like quote_char, name_sep]
See also:
perldoc Catalyst::Manual
perldoc Catalyst::Manual::Intro
perldoc Catalyst::Helper::Model::DBIC::Schema
perldoc Catalyst::Model::DBIC::Schema
perldoc Catalyst::View::TT
=head1 DESCRIPTION
Expand Down
52 changes: 10 additions & 42 deletions script/ibexfarm_fastcgi.pl
100644 → 100755
Original file line number Diff line number Diff line change
@@ -1,40 +1,7 @@
#!/opt/local/bin/perl5.10.1
##!/usr/bin/env perl
#!/usr/bin/env perl

BEGIN { $ENV{CATALYST_ENGINE} ||= 'FastCGI' }

use strict;
use warnings;
use Getopt::Long;
use Pod::Usage;
use FindBin;
use lib "$FindBin::Bin/../lib";
use IbexFarm;

my $help = 0;
my ( $listen, $nproc, $pidfile, $manager, $detach, $keep_stderr );

GetOptions(
'help|?' => \$help,
'listen|l=s' => \$listen,
'nproc|n=i' => \$nproc,
'pidfile|p=s' => \$pidfile,
'manager|M=s' => \$manager,
'daemon|d' => \$detach,
'keeperr|e' => \$keep_stderr,
);

pod2usage(1) if $help;

IbexFarm->run(
$listen,
{ nproc => $nproc,
pidfile => $pidfile,
manager => $manager,
detach => $detach,
keep_stderr => $keep_stderr,
}
);
use Catalyst::ScriptRunner;
Catalyst::ScriptRunner->run('IbexFarm', 'FastCGI');

1;

Expand All @@ -48,21 +15,22 @@ =head1 SYNOPSIS
Options:
-? -help display this help and exits
-l -listen Socket path to listen on
-l --listen Socket path to listen on
(defaults to standard input)
can be HOST:PORT, :PORT or a
filesystem path
-n -nproc specify number of processes to keep
-n --nproc specify number of processes to keep
to serve requests (defaults to 1,
requires -listen)
-p -pidfile specify filename for pid file
-p --pidfile specify filename for pid file
(requires -listen)
-d -daemon daemonize (requires -listen)
-M -manager specify alternate process manager
-d --daemon daemonize (requires -listen)
-M --manager specify alternate process manager
(FCGI::ProcManager sub-class)
or empty string to disable
-e -keeperr send error messages to STDOUT, not
-e --keeperr send error messages to STDOUT, not
to the webserver
--proc_title Set the process title (is possible)
=head1 DESCRIPTION
Expand Down
152 changes: 26 additions & 126 deletions script/ibexfarm_server.pl
100644 → 100755
Original file line number Diff line number Diff line change
@@ -1,144 +1,43 @@
#!/usr/bin/env perl

BEGIN {
$ENV{CATALYST_ENGINE} ||= 'HTTP';
$ENV{CATALYST_SCRIPT_GEN} = 39;
require Catalyst::Engine::HTTP;
$ENV{CATALYST_SCRIPT_GEN} = 40;
}

use strict;
use warnings;
use Getopt::Long;
use Pod::Usage;
use FindBin;
use lib "$FindBin::Bin/../lib";

my $debug = 0;
my $fork = 0;
my $help = 0;
my $host = undef;
my $port = $ENV{IBEXFARM_PORT} || $ENV{CATALYST_PORT} || 3000;
my $keepalive = 0;
my $restart = $ENV{IBEXFARM_RELOAD} || $ENV{CATALYST_RELOAD} || 0;
my $background = 0;
my $pidfile = undef;

my $check_interval;
my $file_regex;
my $watch_directory;
my $follow_symlinks;

my @argv = @ARGV;

GetOptions(
'debug|d' => \$debug,
'fork|f' => \$fork,
'help|?' => \$help,
'host=s' => \$host,
'port|p=s' => \$port,
'keepalive|k' => \$keepalive,
'restart|r' => \$restart,
'restartdelay|rd=s' => \$check_interval,
'restartregex|rr=s' => \$file_regex,
'restartdirectory=s@' => \$watch_directory,
'followsymlinks' => \$follow_symlinks,
'background' => \$background,
'pidfile=s' => \$pidfile,
);

pod2usage(1) if $help;

if ( $debug ) {
$ENV{CATALYST_DEBUG} = 1;
}

# If we load this here, then in the case of a restarter, it does not
# need to be reloaded for each restart.
require Catalyst;

# If this isn't done, then the Catalyst::Devel tests for the restarter
# fail.
$| = 1 if $ENV{HARNESS_ACTIVE};

my $runner = sub {
# This is require instead of use so that the above environment
# variables can be set at runtime.
require IbexFarm;

IbexFarm->run(
$port, $host,
{
argv => \@argv,
'fork' => $fork,
keepalive => $keepalive,
background => $background,
pidfile => $pidfile,
}
);
};

if ( $restart ) {
die "Cannot run in the background and also watch for changed files.\n"
if $background;

require Catalyst::Restarter;

my $subclass = Catalyst::Restarter->pick_subclass;

my %args;
$args{follow_symlinks} = 1
if $follow_symlinks;
$args{directories} = $watch_directory
if defined $watch_directory;
$args{sleep_interval} = $check_interval
if defined $check_interval;
$args{filter} = qr/$file_regex/
if defined $file_regex;

my $restarter = $subclass->new(
%args,
start_sub => $runner,
argv => \@argv,
);

$restarter->run_and_watch;
}
else {
$runner->();
}
use Catalyst::ScriptRunner;
Catalyst::ScriptRunner->run('IbexFarm', 'Server');

1;

=head1 NAME
ibexfarm_server.pl - Catalyst Testserver
ibexfarm_server.pl - Catalyst Test Server
=head1 SYNOPSIS
ibexfarm_server.pl [options]
Options:
-d -debug force debug mode
-f -fork handle each request in a new process
(defaults to false)
-? -help display this help and exits
-host host (defaults to all)
-p -port port (defaults to 3000)
-k -keepalive enable keep-alive connections
-r -restart restart when files get modified
(defaults to false)
-rd -restartdelay delay between file checks
(ignored if you have Linux::Inotify2 installed)
-rr -restartregex regex match files that trigger
a restart when modified
(defaults to '\.yml$|\.yaml$|\.conf|\.pm$')
-restartdirectory the directory to search for
modified files, can be set mulitple times
(defaults to '[SCRIPT_DIR]/..')
-follow_symlinks follow symlinks in search directories
(defaults to false. this is a no-op on Win32)
-background run the process in the background
-pidfile specify filename for pid file
-d --debug force debug mode
-f --fork handle each request in a new process
(defaults to false)
-? --help display this help and exits
-h --host host (defaults to all)
-p --port port (defaults to 3000)
-k --keepalive enable keep-alive connections
-r --restart restart when files get modified
(defaults to false)
-rd --restart_delay delay between file checks
(ignored if you have Linux::Inotify2 installed)
-rr --restart_regex regex match files that trigger
a restart when modified
(defaults to '\.yml$|\.yaml$|\.conf|\.pm$')
--restart_directory the directory to search for
modified files, can be set multiple times
(defaults to '[SCRIPT_DIR]/..')
--follow_symlinks follow symlinks in search directories
(defaults to false. this is a no-op on Win32)
--background run the process in the background
--pidfile specify filename for pid file
See also:
perldoc Catalyst::Manual
Expand All @@ -158,3 +57,4 @@ =head1 COPYRIGHT
it under the same terms as Perl itself.
=cut

19 changes: 3 additions & 16 deletions script/ibexfarm_test.pl
100644 → 100755
Original file line number Diff line number Diff line change
@@ -1,20 +1,7 @@
#!/usr/bin/env perl

use strict;
use warnings;
use Getopt::Long;
use Pod::Usage;
use FindBin;
use lib "$FindBin::Bin/../lib";
use Catalyst::Test 'IbexFarm';

my $help = 0;

GetOptions( 'help|?' => \$help );

pod2usage(1) if ( $help || !$ARGV[0] );

print request($ARGV[0])->content . "\n";
use Catalyst::ScriptRunner;
Catalyst::ScriptRunner->run('IbexFarm', 'Test');

1;

Expand All @@ -27,7 +14,7 @@ =head1 SYNOPSIS
ibexfarm_test.pl [options] uri
Options:
-help display this help and exits
--help display this help and exits
Examples:
ibexfarm_test.pl http://localhost/some_action
Expand Down

0 comments on commit d304d24

Please sign in to comment.