extends 'Catalyst';
-use Catalyst qw/-Debug
+use Catalyst qw/
ConfigLoader
Static::Simple
StackTrace/;
__PACKAGE__->config(
name => 'Gitalist',
default_view => 'Default',
+ default_model => 'Git', # Yes, we are going to be changing this.
+ # Set to 1 to make your fcgi die the request after you push :)
+ exit_at_end_of_request_if_updated => 0,
);
+{
+ my $version;
+ my $get_version = sub {
+ my $gitdir = shift->path_to('.git');
+ my $version = qx{cat "$gitdir/`cut -d' ' -f2 .git/HEAD`"};
+ chomp $version;
+ return $version;
+ };
+
+ after setup_finalize => sub {
+ my $c = shift;
+ $version = $c->$get_version
+ if $c->config->{exit_at_end_of_request_if_updated};
+ };
+ after handle_request => sub {
+ my $c = shift;
+ if ($version) {
+ my $new = $c->$get_version;
+ exit 0 unless $new eq $version;
+ }
+ };
+}
+
+
# Start the application
__PACKAGE__->setup();
around uri_for => sub {
my ($orig, $c) = (shift, shift);
+ local $c->stash->{current_model}; # FIXME - for zts..
+ my $hash = ref($_[-1]) eq 'HASH' ? pop @_ : {};
my $params = Catalyst::Utils::merge_hashes(
- { p => $c->model('Git')->project },
- ref($_[-1]) eq 'HASH' ? pop @_ : {}
+ { p => $hash->{p} || $c->model()->project },
+ $hash,
);
(my $uri = $c->$orig(@_, $params))
=~ tr[&][;];