X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FGitalist%2FController%2FRepository.pm;h=ec28dbb8fed51547b7da167d41af3ac9c9c6e425;hb=2298d93ff984748b0c15d19bad6fdebb1d81c4f1;hp=c890d955a5fc9234afa9145ffa7c7b1cd186c237;hpb=b132dce651d88157285ccf0bb59705fa743696a7;p=catagits%2FGitalist.git diff --git a/lib/Gitalist/Controller/Repository.pm b/lib/Gitalist/Controller/Repository.pm index c890d95..ec28dbb 100644 --- a/lib/Gitalist/Controller/Repository.pm +++ b/lib/Gitalist/Controller/Repository.pm @@ -1,8 +1,5 @@ package Gitalist::Controller::Repository; use Moose; -use XML::Atom::Feed; -use XML::Atom::Entry; -use XML::RSS; use Sys::Hostname qw/hostname/; use namespace::autoclean; @@ -11,39 +8,89 @@ with 'Gitalist::URIStructure::Repository'; sub base : Chained('/base') PathPart('') CaptureArgs(0) {} -=head2 atom +=encoding UTF-8 -Provides an atom feed for a given repository. +=head1 NAME -=cut +Gitalist::Controller::Repository - Controller::Repository module for Gitalist -sub atom : Chained('find') Args(0) { - my($self, $c) = @_; +=head2 search - my $feed = XML::Atom::Feed->new; +The action for the search form. - my $host = lc hostname(); - $feed->title($host . ' - ' . Gitalist->config->{name}); - $feed->updated(~~DateTime->now); +=cut +sub search : Chained('find') Args(0) { + my($self, $c) = @_; my $repository = $c->stash->{Repository}; + # Lifted from /shortlog. my %logargs = ( - sha1 => $repository->head_hash, - count => Gitalist->config->{paging}{log} || 25, + sha1 => $repository->head_hash, +# count => Gitalist->config->{paging}{log}, +# ($c->req->param('f') ? (file => $c->req->param('f')) : ()), + search => { + type => $c->req->param('type'), + text => $c->req->param('text'), + regexp => $c->req->param('regexp') || 0, + }, ); - my $mk_title = $c->stash->{short_cmt}; - for my $commit ($repository->list_revs(%logargs)) { - my $entry = XML::Atom::Entry->new; - $entry->title( $mk_title->($commit->comment) ); - $entry->id($c->uri_for_action('/commit/commit', [$repository->name, $commit->sha1])); - # XXX FIXME Needs work ... - $entry->content($commit->comment); - $feed->add_entry($entry); - } + $c->stash( +# commit => $commit, + results => [$repository->list_revs(%logargs)], + # This could be added - page => $page, + ); +} + +=head2 tree + +Provide a simple redirect to C. + +=cut - $c->response->body($feed->as_xml); - $c->response->content_type('application/atom+xml'); +sub tree : Chained('find') Args(0) { + my($self, $c) = @_; + $c->res->redirect($c->uri_for_action('/ref/tree', [$c->stash->{Repository}->name, 'HEAD'])); + $c->res->status(301); +} + +=head2 atom + +Provides an atom feed for a given repository. + +=cut + +sub atom : Chained('find') Does('FilenameArgs') Args() { + my ($self, $c) = @_; + + my $host = lc hostname(); + $c->stash( + title => $host . ' - ' . Gitalist->config->{name}, + updated => DateTime->now + ); + + my $repository = $c->stash->{Repository}; + my %logargs = ( + sha1 => $repository->head_hash, + count => Gitalist->config->{paging}{log} || 25, + ($c->stash->{filename} ? (file => $c->stash->{filename}) : ()), + ); + + my @revs; + my $mk_title = $c->stash->{short_cmt}; + for my $commit ($repository->list_revs(%logargs)) { + my $entry = {}; + $entry->{title} = $mk_title->($commit->comment); + $entry->{id} = $c->uri_for_action('/ref/commit', [$repository->name, $commit->sha1]); + # XXX FIXME Needs work ... + $entry->{content} = $commit->comment; + push(@revs, $entry); + } + $c->stash( + Commits => \@revs, + no_wrapper => 1, + ); + $c->response->content_type('application/atom+xml'); } =head2 rss @@ -52,37 +99,35 @@ Provides an RSS feed for a given repository. =cut -sub rss : Chained('find') Args(0) { +sub rss : Chained('find') Does('FilenameArgs') Args() { my ($self, $c) = @_; my $repository = $c->stash->{Repository}; - my $rss = XML::RSS->new(version => '2.0'); - $rss->channel( + $c->stash( title => lc(Sys::Hostname::hostname()) . ' - ' . Gitalist->config->{name}, - link => $c->uri_for('summary', {p=>$repository->name}), language => 'en', - description => $repository->description, pubDate => DateTime->now, lastBuildDate => DateTime->now, + no_wrapper => 1, ); my %logargs = ( sha1 => $repository->head_hash, count => Gitalist->config->{paging}{log} || 25, -# ($c->req->param('f') ? (file => $c->req->param('f')) : ()) + ($c->stash->{filename} ? (file => $c->stash->{filename}) : ()), ); + my @revs; my $mk_title = $c->stash->{short_cmt}; for my $commit ($repository->list_revs(%logargs)) { # XXX FIXME Needs work .... - $rss->add_item( + push(@revs, { title => $mk_title->($commit->comment), - permaLink => $c->uri_for_action('/commit/commit', [$repository->name, $commit->sha1]), + permaLink => $c->uri_for_action('/ref/commit', [$repository->name, $commit->sha1]), description => $commit->comment, - ); + }); } - - $c->response->body($rss->as_string); + $c->stash(Commits => \@revs); $c->response->content_type('application/rss+xml'); }