--- /dev/null
+This file documents the revision history for Perl extension LolCatalyst::Lite.
+
+0.01 2008-09-13 01:47:04
+ - initial revision, generated by Catalyst
--- /dev/null
+# IMPORTANT: if you delete this file your app will not work as
+# expected. you have been warned
+use inc::Module::Install;
+
+name 'LolCatalyst-Lite';
+all_from 'lib/LolCatalyst/Lite.pm';
+
+requires 'Catalyst::Runtime' => '5.7014';
+requires 'Catalyst::Plugin::ConfigLoader';
+requires 'Catalyst::Plugin::Static::Simple';
+requires 'Catalyst::Action::RenderView';
+requires 'parent';
+requires 'Config::General'; # This should reflect the config file format you've chosen
+ # See Catalyst::Plugin::ConfigLoader for supported formats
+requires 'Acme::LOLCAT';
+requires 'Catalyst::Plugin::Unicode';
+requires 'Catalyst::View::TT';
+requires 'Catalyst::View::JSON';
+requires 'Acme::Bleach'; # test
+catalyst;
+
+install_script glob('script/*.pl');
+auto_install;
+WriteAll;
--- /dev/null
+Run script/lolcatalyst_lite_server.pl to test the application.
--- /dev/null
+package LolCatalyst::Lite;
+
+use strict;
+use warnings;
+
+use Catalyst::Runtime '5.70';
+
+# Set flags and add plugins for the application
+#
+# -Debug: activates the debug mode for very useful log messages
+# ConfigLoader: will load the configuration from a Config::General file in the
+# application's home directory
+# Static::Simple: will serve static files from the application's root
+# directory
+
+use parent qw/Catalyst/;
+use Catalyst qw/-Debug
+ ConfigLoader
+ Static::Simple/;
+our $VERSION = '0.01';
+
+# Configure the application.
+#
+# Note that settings in lolcatalyst_lite.conf (or other external
+# configuration file that you set up manually) take precedence
+# over this when using ConfigLoader. Thus configuration
+# details given here can function as a default configuration,
+# with a external configuration file acting as an override for
+# local deployment.
+
+__PACKAGE__->config( name => 'LolCatalyst::Lite' );
+
+# Start the application
+__PACKAGE__->setup();
+
+
+=head1 NAME
+
+LolCatalyst::Lite - Catalyst based application
+
+=head1 SYNOPSIS
+
+ script/lolcatalyst_lite_server.pl
+
+=head1 DESCRIPTION
+
+[enter your description here]
+
+=head1 SEE ALSO
+
+L<LolCatalyst::Lite::Controller::Root>, L<Catalyst>
+
+=head1 AUTHOR
+
+Freya Jarrett
+
+=head1 LICENSE
+
+This library is free software, you can redistribute it and/or modify
+it under the same terms as Perl itself.
+
+=cut
+
+1;
--- /dev/null
+package LolCatalyst::Lite::Controller::Root;
+
+use strict;
+use warnings;
+use parent 'Catalyst::Controller';
+
+__PACKAGE__->config->{namespace} = '';
+
+sub index :Path :Args(0) {
+ my ( $self, $c ) = @_;
+}
+
+sub default :Path {
+ my ( $self, $c ) = @_;
+ $c->response->status(404);
+ $c->response->body( 'Page not found' );
+}
+
+sub translate :Local {
+ my ($self, $c) = @_;
+ my $lol = $c->req->body_params->{lol}; # only for a POST request
+ # $c->req->params->{lol} would catch GET or POST
+ # $c->req->query_params would catch GET params only
+ $c->stash(
+ lol => $lol,
+ result => $c->model('Translate')->translate($lol),
+ template => 'index.tt',
+ );
+}
+
+sub translate_service : Local {
+ my ($self, $c) = @_;
+ $c->forward('translate');
+ $c->stash->{current_view} = 'Service';
+}
+
+sub end : ActionClass('RenderView') {
+ my ($self, $c) = @_;
+ my $errors = scalar @{$c->error};
+ if ($errors) {
+ $c->res->status(500);
+ $c->res->body('internal server error');
+ $c->clear_errors;
+ }
+}
+
+1;
--- /dev/null
+package LolCatalyst::Lite::Model::Translate;
+
+use strict;
+use warnings;
+use parent 'Catalyst::Model';
+
+use Acme::LOLCAT ();
+use Memoize;
+memoize ('translate');
+
+sub translate {
+ my ($self, $text) = @_;
+ return Acme::LOLCAT::translate($text);
+}
+
+1;
--- /dev/null
+package LolCatalyst::Lite::View::Service;
+
+use strict;
+use base 'Catalyst::View::JSON';
+
+=head1 NAME
+
+LolCatalyst::Lite::View::Service - Catalyst JSON View
+
+=head1 SYNOPSIS
+
+See L<LolCatalyst::Lite>
+
+=head1 DESCRIPTION
+
+Catalyst JSON View.
+
+=head1 AUTHOR
+
+Freya Jarrett
+
+=head1 LICENSE
+
+This library is free software, you can redistribute it and/or modify
+it under the same terms as Perl itself.
+
+=cut
+
+__PACKAGE__->config({ expose_stash => [ qw/lol result/ ] });
+
+1;
--- /dev/null
+package LolCatalyst::Lite::View::Web;
+
+use strict;
+use base 'Catalyst::View::TT';
+
+__PACKAGE__->config(TEMPLATE_EXTENSION => '.tt');
+
+=head1 NAME
+
+LolCatalyst::Lite::View::Web - TT View for LolCatalyst::Lite
+
+=head1 DESCRIPTION
+
+TT View for LolCatalyst::Lite.
+
+=head1 AUTHOR
+
+=head1 SEE ALSO
+
+L<LolCatalyst::Lite>
+
+Freya Jarrett
+
+=head1 LICENSE
+
+This library is free software, you can redistribute it and/or modify
+it under the same terms as Perl itself.
+
+=cut
+
+1;
--- /dev/null
+# rename this file to LolCatalyst::Lite.yml and put a : in front of "name" if
+# you want to use yaml like in old versions of Catalyst
+name LolCatalyst::Lite
+default_view Web
--- /dev/null
+[% WRAPPER page.tt title = c.config.name ; END %]
+ [% IF result %]<p>[% lol _ ": " _ result %]</p> [% END %]
+<form name="translate" method=POST action="translate">
+ <input type="text" name="lol" value="" title="enter text to translate">
+ <input type="submit" value="Translate">
+ </form>
--- /dev/null
+<!DOCTYPE html
+ PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
+ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US" xml:lang="en-US">
+<head>
+<title>[% title %]</title>
+<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
+</head>
+<body>
+[% content %]
+</body>
+</html>
--- /dev/null
+#!/Users/fj/perl-bin/bin/perl -w
+
+BEGIN { $ENV{CATALYST_ENGINE} ||= 'CGI' }
+
+use strict;
+use warnings;
+use FindBin;
+use lib "$FindBin::Bin/../lib";
+use LolCatalyst::Lite;
+
+LolCatalyst::Lite->run;
+
+1;
+
+=head1 NAME
+
+lolcatalyst_lite_cgi.pl - Catalyst CGI
+
+=head1 SYNOPSIS
+
+See L<Catalyst::Manual>
+
+=head1 DESCRIPTION
+
+Run a Catalyst application as a cgi script.
+
+=head1 AUTHORS
+
+Catalyst Contributors, see Catalyst.pm
+
+=head1 COPYRIGHT
+
+
+This library is free software, you can redistribute it and/or modify
+it under the same terms as Perl itself.
+
+=cut
--- /dev/null
+#!/Users/fj/perl-bin/bin/perl -w
+
+use strict;
+use warnings;
+use Getopt::Long;
+use Pod::Usage;
+use Catalyst::Helper;
+
+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( 'LolCatalyst::Lite', @ARGV );
+
+1;
+
+=head1 NAME
+
+lolcatalyst_lite_create.pl - Create a new Catalyst Component
+
+=head1 SYNOPSIS
+
+lolcatalyst_lite_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
+
+ Examples:
+ lolcatalyst_lite_create.pl controller My::Controller
+ lolcatalyst_lite_create.pl controller My::Controller BindLex
+ lolcatalyst_lite_create.pl -mechanize controller My::Controller
+ lolcatalyst_lite_create.pl view My::View
+ lolcatalyst_lite_create.pl view MyView TT
+ lolcatalyst_lite_create.pl view TT TT
+ lolcatalyst_lite_create.pl model My::Model
+ lolcatalyst_lite_create.pl model SomeDB DBIC::Schema MyApp::Schema create=dynamic\
+ dbi:SQLite:/tmp/my.db
+ lolcatalyst_lite_create.pl model AnotherDB DBIC::Schema MyApp::Schema create=static\
+ dbi:Pg:dbname=foo root 4321
+
+ See also:
+ perldoc Catalyst::Manual
+ perldoc Catalyst::Manual::Intro
+
+=head1 DESCRIPTION
+
+Create a new Catalyst Component.
+
+Existing component files are not overwritten. If any of the component files
+to be created already exist the file will be written with a '.new' suffix.
+This behavior can be suppressed with the C<-force> option.
+
+=head1 AUTHORS
+
+Catalyst Contributors, see Catalyst.pm
+
+=head1 COPYRIGHT
+
+This library is free software, you can redistribute it and/or modify
+it under the same terms as Perl itself.
+
+=cut
--- /dev/null
+#!/Users/fj/perl-bin/bin/perl -w
+
+BEGIN { $ENV{CATALYST_ENGINE} ||= 'FastCGI' }
+
+use strict;
+use warnings;
+use Getopt::Long;
+use Pod::Usage;
+use FindBin;
+use lib "$FindBin::Bin/../lib";
+use LolCatalyst::Lite;
+
+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;
+
+LolCatalyst::Lite->run(
+ $listen,
+ { nproc => $nproc,
+ pidfile => $pidfile,
+ manager => $manager,
+ detach => $detach,
+ keep_stderr => $keep_stderr,
+ }
+);
+
+1;
+
+=head1 NAME
+
+lolcatalyst_lite_fastcgi.pl - Catalyst FastCGI
+
+=head1 SYNOPSIS
+
+lolcatalyst_lite_fastcgi.pl [options]
+
+ Options:
+ -? -help display this help and exits
+ -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
+ to serve requests (defaults to 1,
+ requires -listen)
+ -p -pidfile specify filename for pid file
+ (requires -listen)
+ -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
+ to the webserver
+
+=head1 DESCRIPTION
+
+Run a Catalyst application as fastcgi.
+
+=head1 AUTHORS
+
+Catalyst Contributors, see Catalyst.pm
+
+=head1 COPYRIGHT
+
+This library is free software, you can redistribute it and/or modify
+it under the same terms as Perl itself.
+
+=cut
--- /dev/null
+#!/Users/fj/perl-bin/bin/perl -w
+
+BEGIN {
+ $ENV{CATALYST_ENGINE} ||= 'HTTP';
+ $ENV{CATALYST_SCRIPT_GEN} = 31;
+ require Catalyst::Engine::HTTP;
+}
+
+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{LOLCATALYST_LITE_PORT} || $ENV{CATALYST_PORT} || 3000;
+my $keepalive = 0;
+my $restart = $ENV{LOLCATALYST_LITE_RELOAD} || $ENV{CATALYST_RELOAD} || 0;
+my $restart_delay = 1;
+my $restart_regex = '(?:/|^)(?!\.#).+(?:\.yml$|\.yaml$|\.conf|\.pm)$';
+my $restart_directory = undef;
+my $follow_symlinks = 0;
+
+my @argv = @ARGV;
+
+GetOptions(
+ 'debug|d' => \$debug,
+ 'fork' => \$fork,
+ 'help|?' => \$help,
+ 'host=s' => \$host,
+ 'port=s' => \$port,
+ 'keepalive|k' => \$keepalive,
+ 'restart|r' => \$restart,
+ 'restartdelay|rd=s' => \$restart_delay,
+ 'restartregex|rr=s' => \$restart_regex,
+ 'restartdirectory=s@' => \$restart_directory,
+ 'followsymlinks' => \$follow_symlinks,
+);
+
+pod2usage(1) if $help;
+
+if ( $restart && $ENV{CATALYST_ENGINE} eq 'HTTP' ) {
+ $ENV{CATALYST_ENGINE} = 'HTTP::Restarter';
+}
+if ( $debug ) {
+ $ENV{CATALYST_DEBUG} = 1;
+}
+
+# This is require instead of use so that the above environment
+# variables can be set at runtime.
+require LolCatalyst::Lite;
+
+LolCatalyst::Lite->run( $port, $host, {
+ argv => \@argv,
+ 'fork' => $fork,
+ keepalive => $keepalive,
+ restart => $restart,
+ restart_delay => $restart_delay,
+ restart_regex => qr/$restart_regex/,
+ restart_directory => $restart_directory,
+ follow_symlinks => $follow_symlinks,
+} );
+
+1;
+
+=head1 NAME
+
+lolcatalyst_lite_server.pl - Catalyst Testserver
+
+=head1 SYNOPSIS
+
+lolcatalyst_lite_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
+ -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)
+ See also:
+ perldoc Catalyst::Manual
+ perldoc Catalyst::Manual::Intro
+
+=head1 DESCRIPTION
+
+Run a Catalyst Testserver for this application.
+
+=head1 AUTHORS
+
+Catalyst Contributors, see Catalyst.pm
+
+=head1 COPYRIGHT
+
+This library is free software, you can redistribute it and/or modify
+it under the same terms as Perl itself.
+
+=cut
--- /dev/null
+#!/Users/fj/perl-bin/bin/perl -w
+
+use strict;
+use warnings;
+use Getopt::Long;
+use Pod::Usage;
+use FindBin;
+use lib "$FindBin::Bin/../lib";
+use Catalyst::Test 'LolCatalyst::Lite';
+
+my $help = 0;
+
+GetOptions( 'help|?' => \$help );
+
+pod2usage(1) if ( $help || !$ARGV[0] );
+
+print request($ARGV[0])->content . "\n";
+
+1;
+
+=head1 NAME
+
+lolcatalyst_lite_test.pl - Catalyst Test
+
+=head1 SYNOPSIS
+
+lolcatalyst_lite_test.pl [options] uri
+
+ Options:
+ -help display this help and exits
+
+ Examples:
+ lolcatalyst_lite_test.pl http://localhost/some_action
+ lolcatalyst_lite_test.pl /some_action
+
+ See also:
+ perldoc Catalyst::Manual
+ perldoc Catalyst::Manual::Intro
+
+=head1 DESCRIPTION
+
+Run a Catalyst action from the command line.
+
+=head1 AUTHORS
+
+Catalyst Contributors, see Catalyst.pm
+
+=head1 COPYRIGHT
+
+This library is free software, you can redistribute it and/or modify
+it under the same terms as Perl itself.
+
+=cut
--- /dev/null
+ use strict;
+ use warnings;
+# use Test::More qw/no_plan/;
+use Test::More tests => 13;
+
+
+ BEGIN { use_ok 'Catalyst::Test', 'LolCatalyst::Lite' }
+ use HTTP::Headers;
+ use HTTP::Request::Common;
+
+ # GET request
+
+ my $request = GET('http://localhost');
+ my $response = request($request);
+ ok( $response = request($request), 'Request');
+ ok( $response->is_success, 'Response Successful 2xx' );
+ is( $response->content_type, 'text/html', 'Response Content-Type' );
+ like( $response->content, qr/Translate/, "contains translated string");
+
+ # test request to translate
+
+ $request = POST(
+ 'http://localhost/translate',
+ 'Content-Type' => 'form-data',
+ 'Content' => [
+ 'lol' => 'Can i have a cheese burger?',
+ ]);
+
+ ok( $response = request($request), 'Request');
+ ok( $response->is_success, 'Response Successful 2xx' );
+ is( $response->content_type, 'text/html', 'Response Content-Type' );
+ like( $response->content, qr/CHEEZ/, "contains translated string");
+
+ # test request to translate_service
+
+ $request = POST(
+ 'http://localhost/translate_service',
+ 'Content-Type' => 'form-data',
+ 'Content' => [
+ 'lol' => 'Can i have a cheese burger?',
+ ]);
+ ok($response = request($request), 'Request');
+ ok( $response->is_success, 'Response Successful 2xx' );
+ is( $response->content_type, 'application/json', 'Response Content-Type' );
+ like( $response->content, qr/CHEEZ/, "contains translated string");
+
+
--- /dev/null
+use strict;
+use warnings;
+use Test::More;
+
+eval "use Test::Pod 1.14";
+plan skip_all => 'Test::Pod 1.14 required' if $@;
+plan skip_all => 'set TEST_POD to enable this test' unless $ENV{TEST_POD};
+
+all_pod_files_ok();
--- /dev/null
+use strict;
+use warnings;
+use Test::More;
+
+eval "use Test::Pod::Coverage 1.04";
+plan skip_all => 'Test::Pod::Coverage 1.04 required' if $@;
+plan skip_all => 'set TEST_POD to enable this test' unless $ENV{TEST_POD};
+
+all_pod_coverage_ok();
--- /dev/null
+use strict;
+use warnings;
+use Test::More tests => 1;
+
+BEGIN { use_ok 'LolCatalyst::Lite::Model::Translate' }
+
--- /dev/null
+use strict;
+use warnings;
+use Test::More tests => 1;
+
+BEGIN { use_ok 'LolCatalyst::Lite::View::Service' }
+
--- /dev/null
+use strict;
+use warnings;
+use Test::More tests => 1;
+
+BEGIN { use_ok 'LolCatalyst::Lite::View::Web' }
+