]> git.deb.at Git - deb/packages.git/blobdiff - lib/Packages/DoNewPkg.pm
Packages::DoNewPkg: Support new backend format
[deb/packages.git] / lib / Packages / DoNewPkg.pm
index 059d5a33fa5e859d3dad1c6bc07d884547ac3ff6..9be98d54aba8b0724c13106b7d8cf077220116b2 100644 (file)
@@ -3,10 +3,7 @@ package Packages::DoNewPkg;
 use strict;
 use warnings;
 
-use Benchmark ':hireswallclock';
-use HTML::Entities;
 use POSIX;
-use XML::RSS;
 use CGI ();
 use Exporter;
 our @ISA = qw( Exporter );
@@ -16,21 +13,21 @@ use Packages::I18N::Locale;
 use Packages::Search qw( :all );
 use Packages::CGI;
 use Packages::DB;
-use Packages::Config qw( $TOPDIR @SECTIONS $HOSTNAME $ROOT );
+use Packages::Config qw( $TOPDIR @SECTIONS $ROOT );
 
 sub do_newpkg {
-    my ($params, $opts, $html_header, $menu, $page_content) = @_;
+    my ($params, $opts, $page_content) = @_;
 
     if ($params->{errors}{suite}) {
        fatal_error( _g( "suite not valid or not specified" ) );
     }
     if (@{$opts->{suite}} > 1) {
-       fatal_error( sprintf( _g( "more than one suite specified for show (%s)" ), "@{$opts->{suite}}" ) );
+       fatal_error( sprintf( _g( "more than one suite specified for newpkg (%s)" ), "@{$opts->{suite}}" ) );
     }
 
     my $sort_func = sub { $_[0][0] cmp $_[1][0] };
     $sort_func = sub { $_[0][1] <=> $_[1][1] or $_[0][0] cmp $_[1][0] }
-    if $opts->{mode} eq 'byage';
+       if $opts->{mode} eq 'byage';
 
     my $suite = $opts->{suite}[0];
     my $one_archive = @{$opts->{archive}} == 1 ?
@@ -38,18 +35,19 @@ sub do_newpkg {
     my $one_section = @{$opts->{section}} == 1 ?
        $opts->{section}[0] : undef;
 
-    my @full_path = ($HOSTNAME, $ROOT, $suite);
-    push @full_path, $one_archive if $one_archive;
-    my $full_path = join( '/', @full_path );
-
     my @new_pkgs;
-    #FIXME: move to Packages::DB?
-    open NEWPKG, '<', "$TOPDIR/files/packages/newpkg_info"
-       or die "can't read newpkg_info file: $!";
+    open NEWPKG, '<', "$TOPDIR/files/packages/newpkg_info_$suite"
+       or do {
+           warn "can't read newpkg_info_$suite: $!";
+           fatal_error( sprintf( _g("no newpkg information found for suite %s"),
+                                 $suite) );
+           return;
+    };
     while (<NEWPKG>) {
        chomp;
-       my @data = split /\s/, $_, 10;
+       my @data = split /\s/, $_, 11;
 
+       next unless $data[2]; #removed packages
        next unless $data[3] eq $suite;
        next if $one_archive and $data[2] ne $one_archive;
        next if $one_section and $data[5] ne $one_section;
@@ -60,93 +58,18 @@ sub do_newpkg {
     close NEWPKG;
     
     (my @date)= gmtime();
-    my $now_time = strftime ("%B %d, %Y", @date);
-    my $rss_time = strftime ("%Y-%m-%dT%H:%M+00:00", @date);
-
-    unless ($opts->{format} eq 'rss') {
-       my $title = sprintf( _g( "New Packages in \"%s\"" ), 
-                            $suite );
-       %$html_header = ( title => $title,
-                         title_keywords => "debian, "._g('new packages').", $suite, @{$opts->{section}}",
-                         meta => "<link rel=\"alternate\" type=\"application/rss+xml\" title=\"RSS\" href=\"newpkg?format=rss\">",
-                         lang => $opts->{lang},
-                         print_title => 1 );
-       
-       $$page_content .= "<p>"
-           . sprintf(_g( "The following packages were added to suite <em>%s</em>%s in the Debian archive during the last 7 days."), $suite,
-                     $one_section ? sprintf(_g(" (section %s)"),$one_section):'')."</p>"
-           . "<p>".sprintf( _g( "This information is also available as an <a href=\"%s\">RSS feed</a>." ), "newpkg?format=rss" )
-           ." <a href=\"newpkg?format=rss\"><img src=\"http://planet.debian.org/rss10.png\" alt=\"[RSS 1.0 Feed]\"></a></p>";
-
-       if (@new_pkgs) {
-           $$page_content .= "\n<ul>\n";
-           
-           foreach my $pkg (sort { &$sort_func($a,$b) } @new_pkgs) {
-               $$page_content .= sprintf ("<li><a href=\"%s\">%s</a>\n    -- %s%s",
-                                          $pkg->[0], $pkg->[0],
-                                          encode_entities($pkg->[-1], '"&<>'),
-                                          $pkg->[1] ?
-                                          sprintf(_g(" <em>(%s days old)</em>"),$pkg->[1]):
-                                          '');
-           }
-           $$page_content .= "\n</ul>\n" if @new_pkgs;
-       }
-
-       my $slist = '';
-       if ($one_section) {
-           foreach my $s (@SECTIONS) {
-               $slist .= ", " if $slist;
-               $slist .= $one_section eq $s ? $s :
-                   "<a href=\"../$s/newpkg\">$s</a>";
-           }
-       }
+    #FIXME: compute in the template
+    $page_content->{rss_timestamp} = strftime ("%Y-%m-%dT%H:%M+00:00", @date);
 
-       $$page_content .= '<p class="psmallcenter"><a href="'.make_url('allpackages','').'" title="'.
-           _g( "List of all packages" ) ."\">".
-           _g( "All packages" ) ."</a><br>(<a href=\"".make_url('allpackages','',{format=>'txt.gz'})."\">".
-           _g( "compact compressed textlist" )."</a>)<br>".
-           ($slist ? sprintf(_g( "New packages in %s" ), $slist ):'').
-           "</p>\n";
-
-    } else { # unless ($opts->{format} eq 'rss')
-       my ( $rss_link, $rss_description, $rss_date );
-
-       $rss_description = sprintf(_g( "The following packages were added to suite %s%s in the Debian archive during the last 7 days."), $suite,
-                                  $one_section ? sprintf(_g(" (section %s)"),$one_section):'');
+    if (@new_pkgs) {
+       $page_content->{new_packages} = [ sort { &$sort_func($a,$b) } @new_pkgs ];
+    }
 
-       my $rss = new XML::RSS (version => '1.0');
-       $rss_link = "$full_path".($one_section?"$one_section/":'')."/newpkg?format=rss";
-       $rss->channel(
-                     title        => _g("New Debian Packages"),
-                     link         => $rss_link,
-                     description  => $rss_description,
-                     dc => {
-                         date       => $rss_time,
-                         publisher  => 'debian-www@lists.debian.org',
-                         rights     => 'Copyright '.($date[5]+1900).', SPI Inc.',
-                         language   => $opts->{lang},
-                     },
-                     syn => {
-                         updatePeriod     => "daily",
-                         updateFrequency  => "2",
-#                    updateBase       => "1901-01-01T00:00+00:00",
-                     } );
+    $page_content->{suite} = $suite;
+    $page_content->{section} = $one_section if $one_section;
+    $page_content->{archive} = $one_archive if $one_archive;
+    $page_content->{sections} = \@SECTIONS;
 
-       foreach my $pkg (sort { &$sort_func($a,$b) } @new_pkgs) {
-           $rss->add_item(
-                          title       => $pkg->[0],
-                          link        => "$full_path/$pkg->[0]",
-                          description => $pkg->[-1],
-                          dc => {
-                              subject  => $pkg->[6],
-                          } );
-       }
-       my $charset = get_charset( $opts->{lang} );
-       print &CGI::header( -type => 'application/rss+xml',
-                           -charset => $charset );
-       print $rss->as_string;
-       exit;
-    }
 }
 
 1;