X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=cgi%2Fpkgindex.cgi;h=06154d5c6e9f15aa25cd00200b0fba119a537d7f;hb=dda30e899cb32a91165972a5f902fb370e99c16f;hp=60860473840b47ca20364f75edab9f910979a6eb;hpb=4af907ad36860008ed905d399accbe45f55ca405;p=debbugs.git diff --git a/cgi/pkgindex.cgi b/cgi/pkgindex.cgi index 6086047..06154d5 100755 --- a/cgi/pkgindex.cgi +++ b/cgi/pkgindex.cgi @@ -1,54 +1,64 @@ #!/usr/bin/perl -wT -package debbugs; - +use warnings; use strict; -use POSIX qw(strftime tzset nice); - -#require '/usr/lib/debbugs/errorlib'; -require './common.pl'; +use POSIX qw(strftime nice); -require '/etc/debbugs/config'; -require '/etc/debbugs/text'; +use Debbugs::Config qw(:globals :text :config); +use CGI::Simple; +use Debbugs::CGI qw(:util :url :html); +use Debbugs::Common qw(getmaintainers getparsedaddrs); +use Debbugs::Bugs qw(count_bugs); +use Debbugs::Status qw(:status); +use Debbugs::Packages qw(getpkgsrc); +use Debbugs::Text qw(:templates); nice(5); -my %param = readparse(); +my $q = new CGI::Simple; +my %param = cgi_parameters(query => $q, + single => [qw(indexon repeatmerged archive sortby), + qw(skip max_results first), + ], + default => {indexon => 'pkg', + repeatmerged => 'yes', + archive => 'no', + sortby => 'alpha', + skip => 0, + max_results => 100, + }, + ); -my $indexon = $param{'indexon'} || 'pkg'; -if ($indexon !~ m/^(pkg|src|maint|submitter|tag)$/) { +if (defined $param{first}) { + # rip out all non-words from first + $param{first} =~ s/\W//g; +} +if (defined $param{next}) { + $param{skip}+=$param{max_results}; +} +elsif (defined $param{prev}) { + $param{skip}-=$param{max_results}; + $param{skip} = 0 if $param{skip} < 0; +} + +my $indexon = $param{indexon}; +if ($param{indexon} !~ m/^(pkg|src|maint|submitter|tag)$/) { quitcgi("You have to choose something to index on"); } -my $repeatmerged = ($param{'repeatmerged'} || "yes") eq "yes"; -my $archive = ($param{'archive'} || "no") eq "yes"; -my $sortby = $param{'sortby'} || 'alpha'; +my $repeatmerged = $param{repeatmerged} eq 'yes'; +my $archive = $param{archive} eq "yes"; +my $sortby = $param{sortby}; if ($sortby !~ m/^(alpha|count)$/) { quitcgi("Don't know how to sort like that"); } -#my $include = $param{'include'} || ""; -#my $exclude = $param{'exclude'} || ""; - my $Archived = $archive ? " Archived" : ""; my %maintainers = %{&getmaintainers()}; my %strings = (); -$ENV{"TZ"} = 'UTC'; -tzset(); - -my $dtime = strftime "%a, %e %b %Y %T UTC", localtime; -my $tail_html = $debbugs::gHTMLTail; -$tail_html = $debbugs::gHTMLTail; -$tail_html =~ s/SUBSTITUTE_DTIME/$dtime/; - -set_option("repeatmerged", $repeatmerged); -set_option("archive", $archive); -#set_option("include", { map {($_,1)} (split /[\s,]+/, $include) }) -# if ($include); -#set_option("exclude", { map {($_,1)} (split /[\s,]+/, $exclude) }) -# if ($exclude); +my $dtime = strftime "%a, %e %b %Y %T UTC", gmtime; my %count; my $tag; @@ -57,40 +67,60 @@ my %htmldescrip = (); my %sortkey = (); if ($indexon eq "pkg") { $tag = "package"; - %count = countbugs(sub {my %d=@_; return splitpackages($d{"pkg"})}); + %count = count_bugs(function => sub {my %d=@_; return splitpackages($d{"pkg"})}, + archive => $archive, + ); + if (defined $param{first}) { + %count = map { + if (/^\Q$param{first}\E/) { + ($_,$count{$_}); + } + else { + (); + } + } keys %count; + } $note = "

Note that with multi-binary packages there may be other\n"; $note .= "reports filed under the different binary package names.

\n"; foreach my $pkg (keys %count) { $sortkey{$pkg} = lc $pkg; $htmldescrip{$pkg} = sprintf('%s (%s)', - pkgurl($pkg), - htmlsanit($pkg), - htmlmaintlinks(sub { $_[0] == 1 ? 'maintainer: ' - : 'maintainers: ' }, - $maintainers{$pkg})); + package_links(package => $pkg, links_only=>1), + html_escape($pkg), + package_links(maint=>$maintainers{$pkg})); } } elsif ($indexon eq "src") { $tag = "source package"; my $pkgsrc = getpkgsrc(); - %count = countbugs(sub {my %d=@_; + if (defined $param{first}) { + %count = map { + if (/^\Q$param{first}\E/) { + ($_,$count{$_}); + } + else { + (); + } + } keys %count; + } + %count = count_bugs(function => sub {my %d=@_; return map { $pkgsrc->{$_} || $_ } splitpackages($d{"pkg"}); - }); + }, + archive => $archive, + ); $note = ""; foreach my $src (keys %count) { $sortkey{$src} = lc $src; $htmldescrip{$src} = sprintf('%s (%s)', - srcurl($src), - htmlsanit($src), - htmlmaintlinks(sub { $_[0] == 1 ? 'maintainer: ' - : 'maintainers: ' }, - $maintainers{$src})); + package_links(src => $src, links_only=>1), + html_escape($src), + package_links(maint => $maintainers{$src})); } } elsif ($indexon eq "maint") { $tag = "maintainer"; my %email2maint = (); - %count = countbugs(sub {my %d=@_; + %count = count_bugs(function => sub {my %d=@_; return map { my @me = getparsedaddrs($maintainers{$_}); foreach my $addr (@me) { @@ -99,43 +129,79 @@ if ($indexon eq "pkg") { } map { $_->address } @me; } splitpackages($d{"pkg"}); - }); + }, + archive => $archive, + ); + if (defined $param{first}) { + %count = map { + if (/^\Q$param{first}\E/) { + ($_,$count{$_}); + } + else { + (); + } + } keys %count; + } $note = "

Note that maintainers may use different Maintainer fields for\n"; $note .= "different packages, so there may be other reports filed under\n"; $note .= "different addresses.

\n"; foreach my $maint (keys %count) { $sortkey{$maint} = lc $email2maint{$maint} || "(unknown)"; - $htmldescrip{$maint} = htmlmaintlinks('', $email2maint{$maint}); + $htmldescrip{$maint} = htmlize_maintlinks('', $email2maint{$maint}); } } elsif ($indexon eq "submitter") { $tag = "submitter"; my %fullname = (); - %count = countbugs(sub {my %d=@_; + %count = count_bugs(function => sub {my %d=@_; my @se = getparsedaddrs($d{"submitter"} || ""); foreach my $addr (@se) { $fullname{$addr->address} = $addr->format unless exists $fullname{$addr->address}; } map { $_->address } @se; - }); + }, + archive => $archive, + ); + if (defined $param{first}) { + %count = map { + if (/^\Q$param{first}\E/) { + ($_,$count{$_}); + } + else { + (); + } + } keys %count; + } foreach my $sub (keys %count) { $sortkey{$sub} = lc $fullname{$sub}; $htmldescrip{$sub} = sprintf('%s', submitterurl($sub), - htmlsanit($fullname{$sub})); + html_escape($fullname{$sub})); } $note = "

Note that people may use different email accounts for\n"; $note .= "different bugs, so there may be other reports filed under\n"; $note .= "different addresses.

\n"; } elsif ($indexon eq "tag") { $tag = "tag"; - %count = countbugs(sub {my %d=@_; return split ' ', $d{tags}; }); + %count = count_bugs(function => sub {my %d=@_; return split ' ', $d{tags}; }, + archive => $archive, + ); + if (defined $param{first}) { + %count = map { + if (/^\Q$param{first}\E/) { + ($_,$count{$_}); + } + else { + (); + } + } keys %count; + } $note = ""; foreach my $keyword (keys %count) { $sortkey{$keyword} = lc $keyword; $htmldescrip{$keyword} = sprintf('%s', tagurl($keyword), - htmlsanit($keyword)); + html_escape($keyword)); } } @@ -146,7 +212,13 @@ if ($sortby eq "count") { } else { # sortby alpha @orderedentries = sort { $sortkey{$a} cmp $sortkey{$b} } keys %count; } +my $skip = $param{skip}; +my $max_results = $param{max_results}; foreach my $x (@orderedentries) { + if (not defined $param{first}) { + $skip-- and next if $skip > 0; + last if --$max_results < 0; + } $result .= "
  • " . $htmldescrip{$x} . " has $count{$x} " . ($count{$x} == 1 ? "bug" : "bugs") . "
  • \n"; } @@ -156,17 +228,42 @@ print "Content-Type: text/html\n\n"; print "\n"; print "\n" . - "$debbugs::gProject$Archived $debbugs::gBug reports by $tag\n" . + "$gProject$Archived $gBug reports by $tag\n" . + qq() . "\n" . '' . "\n"; -print "

    " . "$debbugs::gProject$Archived $debbugs::gBug report logs by $tag" . +print "

    " . "$gProject$Archived $gBug report logs by $tag" . "

    \n"; print $note; +print < + + + + + + +END +if (defined $param{first}) { + print qq(\n); +} +else { + print q(

    ); + if ($param{skip} > 0) { + print q(); + } + if (keys %count > ($param{skip} + $param{max_results})) { + print q(); + } + print qq(

    \n); +} print $result; print "
    \n"; -print "

    $tail_html"; - +print fill_in_template(template=>'html/html_tail', + hole_var => {'&strftime' => \&POSIX::strftime, + }, + ); print "\n";