Merge branch 'lw/gitweb'

* lw/gitweb:
  gitweb: standarize HTTP status codes
This commit is contained in:
Junio C Hamano 2008-06-25 13:19:53 -07:00
commit 78e996451b

View File

@ -386,7 +386,7 @@ $projects_list ||= $projectroot;
our $action = $cgi->param('a'); our $action = $cgi->param('a');
if (defined $action) { if (defined $action) {
if ($action =~ m/[^0-9a-zA-Z\.\-_]/) { if ($action =~ m/[^0-9a-zA-Z\.\-_]/) {
die_error(undef, "Invalid action parameter"); die_error(400, "Invalid action parameter");
} }
} }
@ -399,21 +399,21 @@ if (defined $project) {
($export_ok && !(-e "$projectroot/$project/$export_ok")) || ($export_ok && !(-e "$projectroot/$project/$export_ok")) ||
($strict_export && !project_in_list($project))) { ($strict_export && !project_in_list($project))) {
undef $project; undef $project;
die_error(undef, "No such project"); die_error(404, "No such project");
} }
} }
our $file_name = $cgi->param('f'); our $file_name = $cgi->param('f');
if (defined $file_name) { if (defined $file_name) {
if (!validate_pathname($file_name)) { if (!validate_pathname($file_name)) {
die_error(undef, "Invalid file parameter"); die_error(400, "Invalid file parameter");
} }
} }
our $file_parent = $cgi->param('fp'); our $file_parent = $cgi->param('fp');
if (defined $file_parent) { if (defined $file_parent) {
if (!validate_pathname($file_parent)) { if (!validate_pathname($file_parent)) {
die_error(undef, "Invalid file parent parameter"); die_error(400, "Invalid file parent parameter");
} }
} }
@ -421,21 +421,21 @@ if (defined $file_parent) {
our $hash = $cgi->param('h'); our $hash = $cgi->param('h');
if (defined $hash) { if (defined $hash) {
if (!validate_refname($hash)) { if (!validate_refname($hash)) {
die_error(undef, "Invalid hash parameter"); die_error(400, "Invalid hash parameter");
} }
} }
our $hash_parent = $cgi->param('hp'); our $hash_parent = $cgi->param('hp');
if (defined $hash_parent) { if (defined $hash_parent) {
if (!validate_refname($hash_parent)) { if (!validate_refname($hash_parent)) {
die_error(undef, "Invalid hash parent parameter"); die_error(400, "Invalid hash parent parameter");
} }
} }
our $hash_base = $cgi->param('hb'); our $hash_base = $cgi->param('hb');
if (defined $hash_base) { if (defined $hash_base) {
if (!validate_refname($hash_base)) { if (!validate_refname($hash_base)) {
die_error(undef, "Invalid hash base parameter"); die_error(400, "Invalid hash base parameter");
} }
} }
@ -447,10 +447,10 @@ our @extra_options = $cgi->param('opt');
if (defined @extra_options) { if (defined @extra_options) {
foreach my $opt (@extra_options) { foreach my $opt (@extra_options) {
if (not exists $allowed_options{$opt}) { if (not exists $allowed_options{$opt}) {
die_error(undef, "Invalid option parameter"); die_error(400, "Invalid option parameter");
} }
if (not grep(/^$action$/, @{$allowed_options{$opt}})) { if (not grep(/^$action$/, @{$allowed_options{$opt}})) {
die_error(undef, "Invalid option parameter for this action"); die_error(400, "Invalid option parameter for this action");
} }
} }
} }
@ -458,7 +458,7 @@ if (defined @extra_options) {
our $hash_parent_base = $cgi->param('hpb'); our $hash_parent_base = $cgi->param('hpb');
if (defined $hash_parent_base) { if (defined $hash_parent_base) {
if (!validate_refname($hash_parent_base)) { if (!validate_refname($hash_parent_base)) {
die_error(undef, "Invalid hash parent base parameter"); die_error(400, "Invalid hash parent base parameter");
} }
} }
@ -466,14 +466,14 @@ if (defined $hash_parent_base) {
our $page = $cgi->param('pg'); our $page = $cgi->param('pg');
if (defined $page) { if (defined $page) {
if ($page =~ m/[^0-9]/) { if ($page =~ m/[^0-9]/) {
die_error(undef, "Invalid page parameter"); die_error(400, "Invalid page parameter");
} }
} }
our $searchtype = $cgi->param('st'); our $searchtype = $cgi->param('st');
if (defined $searchtype) { if (defined $searchtype) {
if ($searchtype =~ m/[^a-z]/) { if ($searchtype =~ m/[^a-z]/) {
die_error(undef, "Invalid searchtype parameter"); die_error(400, "Invalid searchtype parameter");
} }
} }
@ -483,7 +483,7 @@ our $searchtext = $cgi->param('s');
our $search_regexp; our $search_regexp;
if (defined $searchtext) { if (defined $searchtext) {
if (length($searchtext) < 2) { if (length($searchtext) < 2) {
die_error(undef, "At least two characters are required for search parameter"); die_error(403, "At least two characters are required for search parameter");
} }
$search_regexp = $search_use_regexp ? $searchtext : quotemeta $searchtext; $search_regexp = $search_use_regexp ? $searchtext : quotemeta $searchtext;
} }
@ -580,11 +580,11 @@ if (!defined $action) {
} }
} }
if (!defined($actions{$action})) { if (!defined($actions{$action})) {
die_error(undef, "Unknown action"); die_error(400, "Unknown action");
} }
if ($action !~ m/^(opml|project_list|project_index)$/ && if ($action !~ m/^(opml|project_list|project_index)$/ &&
!$project) { !$project) {
die_error(undef, "Project needed"); die_error(400, "Project needed");
} }
$actions{$action}->(); $actions{$action}->();
exit; exit;
@ -1665,7 +1665,7 @@ sub git_get_hash_by_path {
$path =~ s,/+$,,; $path =~ s,/+$,,;
open my $fd, "-|", git_cmd(), "ls-tree", $base, "--", $path open my $fd, "-|", git_cmd(), "ls-tree", $base, "--", $path
or die_error(undef, "Open git-ls-tree failed"); or die_error(500, "Open git-ls-tree failed");
my $line = <$fd>; my $line = <$fd>;
close $fd or return undef; close $fd or return undef;
@ -2127,7 +2127,7 @@ sub parse_commit {
"--max-count=1", "--max-count=1",
$commit_id, $commit_id,
"--", "--",
or die_error(undef, "Open git-rev-list failed"); or die_error(500, "Open git-rev-list failed");
%co = parse_commit_text(<$fd>, 1); %co = parse_commit_text(<$fd>, 1);
close $fd; close $fd;
@ -2152,7 +2152,7 @@ sub parse_commits {
$commit_id, $commit_id,
"--", "--",
($filename ? ($filename) : ()) ($filename ? ($filename) : ())
or die_error(undef, "Open git-rev-list failed"); or die_error(500, "Open git-rev-list failed");
while (my $line = <$fd>) { while (my $line = <$fd>) {
my %co = parse_commit_text($line); my %co = parse_commit_text($line);
push @cos, \%co; push @cos, \%co;
@ -2672,11 +2672,26 @@ sub git_footer_html {
"</html>"; "</html>";
} }
# die_error(<http_status_code>, <error_message>)
# Example: die_error(404, 'Hash not found')
# By convention, use the following status codes (as defined in RFC 2616):
# 400: Invalid or missing CGI parameters, or
# requested object exists but has wrong type.
# 403: Requested feature (like "pickaxe" or "snapshot") not enabled on
# this server or project.
# 404: Requested object/revision/project doesn't exist.
# 500: The server isn't configured properly, or
# an internal error occurred (e.g. failed assertions caused by bugs), or
# an unknown error occurred (e.g. the git binary died unexpectedly).
sub die_error { sub die_error {
my $status = shift || "403 Forbidden"; my $status = shift || 500;
my $error = shift || "Malformed query, file missing or permission denied"; my $error = shift || "Internal server error";
git_header_html($status); my %http_responses = (400 => '400 Bad Request',
403 => '403 Forbidden',
404 => '404 Not Found',
500 => '500 Internal Server Error');
git_header_html($http_responses{$status});
print <<EOF; print <<EOF;
<div class="page_body"> <div class="page_body">
<br /><br /> <br /><br />
@ -3937,12 +3952,12 @@ sub git_search_grep_body {
sub git_project_list { sub git_project_list {
my $order = $cgi->param('o'); my $order = $cgi->param('o');
if (defined $order && $order !~ m/none|project|descr|owner|age/) { if (defined $order && $order !~ m/none|project|descr|owner|age/) {
die_error(undef, "Unknown order parameter"); die_error(400, "Unknown order parameter");
} }
my @list = git_get_projects_list(); my @list = git_get_projects_list();
if (!@list) { if (!@list) {
die_error(undef, "No projects found"); die_error(404, "No projects found");
} }
git_header_html(); git_header_html();
@ -3960,12 +3975,12 @@ sub git_project_list {
sub git_forks { sub git_forks {
my $order = $cgi->param('o'); my $order = $cgi->param('o');
if (defined $order && $order !~ m/none|project|descr|owner|age/) { if (defined $order && $order !~ m/none|project|descr|owner|age/) {
die_error(undef, "Unknown order parameter"); die_error(400, "Unknown order parameter");
} }
my @list = git_get_projects_list($project); my @list = git_get_projects_list($project);
if (!@list) { if (!@list) {
die_error(undef, "No forks found"); die_error(404, "No forks found");
} }
git_header_html(); git_header_html();
@ -4094,7 +4109,7 @@ sub git_tag {
my %tag = parse_tag($hash); my %tag = parse_tag($hash);
if (! %tag) { if (! %tag) {
die_error(undef, "Unknown tag object"); die_error(404, "Unknown tag object");
} }
git_print_header_div('commit', esc_html($tag{'name'}), $hash); git_print_header_div('commit', esc_html($tag{'name'}), $hash);
@ -4130,26 +4145,25 @@ sub git_blame {
my $fd; my $fd;
my $ftype; my $ftype;
my ($have_blame) = gitweb_check_feature('blame'); gitweb_check_feature('blame')
if (!$have_blame) { or die_error(403, "Blame view not allowed");
die_error('403 Permission denied', "Permission denied");
} die_error(400, "No file name given") unless $file_name;
die_error('404 Not Found', "File name not defined") if (!$file_name);
$hash_base ||= git_get_head_hash($project); $hash_base ||= git_get_head_hash($project);
die_error(undef, "Couldn't find base commit") unless ($hash_base); die_error(404, "Couldn't find base commit") unless ($hash_base);
my %co = parse_commit($hash_base) my %co = parse_commit($hash_base)
or die_error(undef, "Reading commit failed"); or die_error(404, "Commit not found");
if (!defined $hash) { if (!defined $hash) {
$hash = git_get_hash_by_path($hash_base, $file_name, "blob") $hash = git_get_hash_by_path($hash_base, $file_name, "blob")
or die_error(undef, "Error looking up file"); or die_error(404, "Error looking up file");
} }
$ftype = git_get_type($hash); $ftype = git_get_type($hash);
if ($ftype !~ "blob") { if ($ftype !~ "blob") {
die_error('400 Bad Request', "Object is not a blob"); die_error(400, "Object is not a blob");
} }
open ($fd, "-|", git_cmd(), "blame", '-p', '--', open ($fd, "-|", git_cmd(), "blame", '-p', '--',
$file_name, $hash_base) $file_name, $hash_base)
or die_error(undef, "Open git-blame failed"); or die_error(500, "Open git-blame failed");
git_header_html(); git_header_html();
my $formats_nav = my $formats_nav =
$cgi->a({-href => href(action=>"blob", -replay=>1)}, $cgi->a({-href => href(action=>"blob", -replay=>1)},
@ -4211,7 +4225,7 @@ HTML
print "</td>\n"; print "</td>\n";
} }
open (my $dd, "-|", git_cmd(), "rev-parse", "$full_rev^") open (my $dd, "-|", git_cmd(), "rev-parse", "$full_rev^")
or die_error(undef, "Open git-rev-parse failed"); or die_error(500, "Open git-rev-parse failed");
my $parent_commit = <$dd>; my $parent_commit = <$dd>;
close $dd; close $dd;
chomp($parent_commit); chomp($parent_commit);
@ -4268,9 +4282,9 @@ sub git_blob_plain {
if (defined $file_name) { if (defined $file_name) {
my $base = $hash_base || git_get_head_hash($project); my $base = $hash_base || git_get_head_hash($project);
$hash = git_get_hash_by_path($base, $file_name, "blob") $hash = git_get_hash_by_path($base, $file_name, "blob")
or die_error(undef, "Error lookup file"); or die_error(404, "Cannot find file");
} else { } else {
die_error(undef, "No file name defined"); die_error(400, "No file name defined");
} }
} elsif ($hash =~ m/^[0-9a-fA-F]{40}$/) { } elsif ($hash =~ m/^[0-9a-fA-F]{40}$/) {
# blobs defined by non-textual hash id's can be cached # blobs defined by non-textual hash id's can be cached
@ -4278,7 +4292,7 @@ sub git_blob_plain {
} }
open my $fd, "-|", git_cmd(), "cat-file", "blob", $hash open my $fd, "-|", git_cmd(), "cat-file", "blob", $hash
or die_error(undef, "Open git-cat-file blob '$hash' failed"); or die_error(500, "Open git-cat-file blob '$hash' failed");
# content-type (can include charset) # content-type (can include charset)
$type = blob_contenttype($fd, $file_name, $type); $type = blob_contenttype($fd, $file_name, $type);
@ -4310,9 +4324,9 @@ sub git_blob {
if (defined $file_name) { if (defined $file_name) {
my $base = $hash_base || git_get_head_hash($project); my $base = $hash_base || git_get_head_hash($project);
$hash = git_get_hash_by_path($base, $file_name, "blob") $hash = git_get_hash_by_path($base, $file_name, "blob")
or die_error(undef, "Error lookup file"); or die_error(404, "Cannot find file");
} else { } else {
die_error(undef, "No file name defined"); die_error(400, "No file name defined");
} }
} elsif ($hash =~ m/^[0-9a-fA-F]{40}$/) { } elsif ($hash =~ m/^[0-9a-fA-F]{40}$/) {
# blobs defined by non-textual hash id's can be cached # blobs defined by non-textual hash id's can be cached
@ -4321,7 +4335,7 @@ sub git_blob {
my ($have_blame) = gitweb_check_feature('blame'); my ($have_blame) = gitweb_check_feature('blame');
open my $fd, "-|", git_cmd(), "cat-file", "blob", $hash open my $fd, "-|", git_cmd(), "cat-file", "blob", $hash
or die_error(undef, "Couldn't cat $file_name, $hash"); or die_error(500, "Couldn't cat $file_name, $hash");
my $mimetype = blob_mimetype($fd, $file_name); my $mimetype = blob_mimetype($fd, $file_name);
if ($mimetype !~ m!^(?:text/|image/(?:gif|png|jpeg)$)! && -B $fd) { if ($mimetype !~ m!^(?:text/|image/(?:gif|png|jpeg)$)! && -B $fd) {
close $fd; close $fd;
@ -4402,9 +4416,9 @@ sub git_tree {
} }
$/ = "\0"; $/ = "\0";
open my $fd, "-|", git_cmd(), "ls-tree", '-z', $hash open my $fd, "-|", git_cmd(), "ls-tree", '-z', $hash
or die_error(undef, "Open git-ls-tree failed"); or die_error(500, "Open git-ls-tree failed");
my @entries = map { chomp; $_ } <$fd>; my @entries = map { chomp; $_ } <$fd>;
close $fd or die_error(undef, "Reading tree failed"); close $fd or die_error(404, "Reading tree failed");
$/ = "\n"; $/ = "\n";
my $refs = git_get_references(); my $refs = git_get_references();
@ -4494,16 +4508,16 @@ sub git_snapshot {
my $format = $cgi->param('sf'); my $format = $cgi->param('sf');
if (!@supported_fmts) { if (!@supported_fmts) {
die_error('403 Permission denied', "Permission denied"); die_error(403, "Snapshots not allowed");
} }
# default to first supported snapshot format # default to first supported snapshot format
$format ||= $supported_fmts[0]; $format ||= $supported_fmts[0];
if ($format !~ m/^[a-z0-9]+$/) { if ($format !~ m/^[a-z0-9]+$/) {
die_error(undef, "Invalid snapshot format parameter"); die_error(400, "Invalid snapshot format parameter");
} elsif (!exists($known_snapshot_formats{$format})) { } elsif (!exists($known_snapshot_formats{$format})) {
die_error(undef, "Unknown snapshot format"); die_error(400, "Unknown snapshot format");
} elsif (!grep($_ eq $format, @supported_fmts)) { } elsif (!grep($_ eq $format, @supported_fmts)) {
die_error(undef, "Unsupported snapshot format"); die_error(403, "Unsupported snapshot format");
} }
if (!defined $hash) { if (!defined $hash) {
@ -4531,7 +4545,7 @@ sub git_snapshot {
-status => '200 OK'); -status => '200 OK');
open my $fd, "-|", $cmd open my $fd, "-|", $cmd
or die_error(undef, "Execute git-archive failed"); or die_error(500, "Execute git-archive failed");
binmode STDOUT, ':raw'; binmode STDOUT, ':raw';
print <$fd>; print <$fd>;
binmode STDOUT, ':utf8'; # as set at the beginning of gitweb.cgi binmode STDOUT, ':utf8'; # as set at the beginning of gitweb.cgi
@ -4599,10 +4613,8 @@ sub git_log {
sub git_commit { sub git_commit {
$hash ||= $hash_base || "HEAD"; $hash ||= $hash_base || "HEAD";
my %co = parse_commit($hash); my %co = parse_commit($hash)
if (!%co) { or die_error(404, "Unknown commit object");
die_error(undef, "Unknown commit object");
}
my %ad = parse_date($co{'author_epoch'}, $co{'author_tz'}); my %ad = parse_date($co{'author_epoch'}, $co{'author_tz'});
my %cd = parse_date($co{'committer_epoch'}, $co{'committer_tz'}); my %cd = parse_date($co{'committer_epoch'}, $co{'committer_tz'});
@ -4642,9 +4654,9 @@ sub git_commit {
@diff_opts, @diff_opts,
(@$parents <= 1 ? $parent : '-c'), (@$parents <= 1 ? $parent : '-c'),
$hash, "--" $hash, "--"
or die_error(undef, "Open git-diff-tree failed"); or die_error(500, "Open git-diff-tree failed");
@difftree = map { chomp; $_ } <$fd>; @difftree = map { chomp; $_ } <$fd>;
close $fd or die_error(undef, "Reading git-diff-tree failed"); close $fd or die_error(404, "Reading git-diff-tree failed");
# non-textual hash id's can be cached # non-textual hash id's can be cached
my $expires; my $expires;
@ -4737,33 +4749,33 @@ sub git_object {
open my $fd, "-|", quote_command( open my $fd, "-|", quote_command(
git_cmd(), 'cat-file', '-t', $object_id) . ' 2> /dev/null' git_cmd(), 'cat-file', '-t', $object_id) . ' 2> /dev/null'
or die_error('404 Not Found', "Object does not exist"); or die_error(404, "Object does not exist");
$type = <$fd>; $type = <$fd>;
chomp $type; chomp $type;
close $fd close $fd
or die_error('404 Not Found', "Object does not exist"); or die_error(404, "Object does not exist");
# - hash_base and file_name # - hash_base and file_name
} elsif ($hash_base && defined $file_name) { } elsif ($hash_base && defined $file_name) {
$file_name =~ s,/+$,,; $file_name =~ s,/+$,,;
system(git_cmd(), "cat-file", '-e', $hash_base) == 0 system(git_cmd(), "cat-file", '-e', $hash_base) == 0
or die_error('404 Not Found', "Base object does not exist"); or die_error(404, "Base object does not exist");
# here errors should not hapen # here errors should not hapen
open my $fd, "-|", git_cmd(), "ls-tree", $hash_base, "--", $file_name open my $fd, "-|", git_cmd(), "ls-tree", $hash_base, "--", $file_name
or die_error(undef, "Open git-ls-tree failed"); or die_error(500, "Open git-ls-tree failed");
my $line = <$fd>; my $line = <$fd>;
close $fd; close $fd;
#'100644 blob 0fa3f3a66fb6a137f6ec2c19351ed4d807070ffa panic.c' #'100644 blob 0fa3f3a66fb6a137f6ec2c19351ed4d807070ffa panic.c'
unless ($line && $line =~ m/^([0-9]+) (.+) ([0-9a-fA-F]{40})\t/) { unless ($line && $line =~ m/^([0-9]+) (.+) ([0-9a-fA-F]{40})\t/) {
die_error('404 Not Found', "File or directory for given base does not exist"); die_error(404, "File or directory for given base does not exist");
} }
$type = $2; $type = $2;
$hash = $3; $hash = $3;
} else { } else {
die_error('404 Not Found', "Not enough information to find object"); die_error(400, "Not enough information to find object");
} }
print $cgi->redirect(-uri => href(action=>$type, -full=>1, print $cgi->redirect(-uri => href(action=>$type, -full=>1,
@ -4788,12 +4800,12 @@ sub git_blobdiff {
open $fd, "-|", git_cmd(), "diff-tree", '-r', @diff_opts, open $fd, "-|", git_cmd(), "diff-tree", '-r', @diff_opts,
$hash_parent_base, $hash_base, $hash_parent_base, $hash_base,
"--", (defined $file_parent ? $file_parent : ()), $file_name "--", (defined $file_parent ? $file_parent : ()), $file_name
or die_error(undef, "Open git-diff-tree failed"); or die_error(500, "Open git-diff-tree failed");
@difftree = map { chomp; $_ } <$fd>; @difftree = map { chomp; $_ } <$fd>;
close $fd close $fd
or die_error(undef, "Reading git-diff-tree failed"); or die_error(404, "Reading git-diff-tree failed");
@difftree @difftree
or die_error('404 Not Found', "Blob diff not found"); or die_error(404, "Blob diff not found");
} elsif (defined $hash && } elsif (defined $hash &&
$hash =~ /[0-9a-fA-F]{40}/) { $hash =~ /[0-9a-fA-F]{40}/) {
@ -4802,23 +4814,23 @@ sub git_blobdiff {
# read filtered raw output # read filtered raw output
open $fd, "-|", git_cmd(), "diff-tree", '-r', @diff_opts, open $fd, "-|", git_cmd(), "diff-tree", '-r', @diff_opts,
$hash_parent_base, $hash_base, "--" $hash_parent_base, $hash_base, "--"
or die_error(undef, "Open git-diff-tree failed"); or die_error(500, "Open git-diff-tree failed");
@difftree = @difftree =
# ':100644 100644 03b21826... 3b93d5e7... M ls-files.c' # ':100644 100644 03b21826... 3b93d5e7... M ls-files.c'
# $hash == to_id # $hash == to_id
grep { /^:[0-7]{6} [0-7]{6} [0-9a-fA-F]{40} $hash/ } grep { /^:[0-7]{6} [0-7]{6} [0-9a-fA-F]{40} $hash/ }
map { chomp; $_ } <$fd>; map { chomp; $_ } <$fd>;
close $fd close $fd
or die_error(undef, "Reading git-diff-tree failed"); or die_error(404, "Reading git-diff-tree failed");
@difftree @difftree
or die_error('404 Not Found', "Blob diff not found"); or die_error(404, "Blob diff not found");
} else { } else {
die_error('404 Not Found', "Missing one of the blob diff parameters"); die_error(400, "Missing one of the blob diff parameters");
} }
if (@difftree > 1) { if (@difftree > 1) {
die_error('404 Not Found', "Ambiguous blob diff specification"); die_error(400, "Ambiguous blob diff specification");
} }
%diffinfo = parse_difftree_raw_line($difftree[0]); %diffinfo = parse_difftree_raw_line($difftree[0]);
@ -4839,7 +4851,7 @@ sub git_blobdiff {
'-p', ($format eq 'html' ? "--full-index" : ()), '-p', ($format eq 'html' ? "--full-index" : ()),
$hash_parent_base, $hash_base, $hash_parent_base, $hash_base,
"--", (defined $file_parent ? $file_parent : ()), $file_name "--", (defined $file_parent ? $file_parent : ()), $file_name
or die_error(undef, "Open git-diff-tree failed"); or die_error(500, "Open git-diff-tree failed");
} }
# old/legacy style URI # old/legacy style URI
@ -4875,9 +4887,9 @@ sub git_blobdiff {
open $fd, "-|", git_cmd(), "diff", @diff_opts, open $fd, "-|", git_cmd(), "diff", @diff_opts,
'-p', ($format eq 'html' ? "--full-index" : ()), '-p', ($format eq 'html' ? "--full-index" : ()),
$hash_parent, $hash, "--" $hash_parent, $hash, "--"
or die_error(undef, "Open git-diff failed"); or die_error(500, "Open git-diff failed");
} else { } else {
die_error('404 Not Found', "Missing one of the blob diff parameters") die_error(400, "Missing one of the blob diff parameters")
unless %diffinfo; unless %diffinfo;
} }
@ -4910,7 +4922,7 @@ sub git_blobdiff {
print "X-Git-Url: " . $cgi->self_url() . "\n\n"; print "X-Git-Url: " . $cgi->self_url() . "\n\n";
} else { } else {
die_error(undef, "Unknown blobdiff format"); die_error(400, "Unknown blobdiff format");
} }
# patch # patch
@ -4945,10 +4957,8 @@ sub git_blobdiff_plain {
sub git_commitdiff { sub git_commitdiff {
my $format = shift || 'html'; my $format = shift || 'html';
$hash ||= $hash_base || "HEAD"; $hash ||= $hash_base || "HEAD";
my %co = parse_commit($hash); my %co = parse_commit($hash)
if (!%co) { or die_error(404, "Unknown commit object");
die_error(undef, "Unknown commit object");
}
# choose format for commitdiff for merge # choose format for commitdiff for merge
if (! defined $hash_parent && @{$co{'parents'}} > 1) { if (! defined $hash_parent && @{$co{'parents'}} > 1) {
@ -5030,7 +5040,7 @@ sub git_commitdiff {
open $fd, "-|", git_cmd(), "diff-tree", '-r', @diff_opts, open $fd, "-|", git_cmd(), "diff-tree", '-r', @diff_opts,
"--no-commit-id", "--patch-with-raw", "--full-index", "--no-commit-id", "--patch-with-raw", "--full-index",
$hash_parent_param, $hash, "--" $hash_parent_param, $hash, "--"
or die_error(undef, "Open git-diff-tree failed"); or die_error(500, "Open git-diff-tree failed");
while (my $line = <$fd>) { while (my $line = <$fd>) {
chomp $line; chomp $line;
@ -5042,10 +5052,10 @@ sub git_commitdiff {
} elsif ($format eq 'plain') { } elsif ($format eq 'plain') {
open $fd, "-|", git_cmd(), "diff-tree", '-r', @diff_opts, open $fd, "-|", git_cmd(), "diff-tree", '-r', @diff_opts,
'-p', $hash_parent_param, $hash, "--" '-p', $hash_parent_param, $hash, "--"
or die_error(undef, "Open git-diff-tree failed"); or die_error(500, "Open git-diff-tree failed");
} else { } else {
die_error(undef, "Unknown commitdiff format"); die_error(400, "Unknown commitdiff format");
} }
# non-textual hash id's can be cached # non-textual hash id's can be cached
@ -5128,19 +5138,15 @@ sub git_history {
$page = 0; $page = 0;
} }
my $ftype; my $ftype;
my %co = parse_commit($hash_base); my %co = parse_commit($hash_base)
if (!%co) { or die_error(404, "Unknown commit object");
die_error(undef, "Unknown commit object");
}
my $refs = git_get_references(); my $refs = git_get_references();
my $limit = sprintf("--max-count=%i", (100 * ($page+1))); my $limit = sprintf("--max-count=%i", (100 * ($page+1)));
my @commitlist = parse_commits($hash_base, 101, (100 * $page), my @commitlist = parse_commits($hash_base, 101, (100 * $page),
$file_name, "--full-history"); $file_name, "--full-history")
if (!@commitlist) { or die_error(404, "No such file or directory on given branch");
die_error('404 Not Found', "No such file or directory on given branch");
}
if (!defined $hash && defined $file_name) { if (!defined $hash && defined $file_name) {
# some commits could have deleted file in question, # some commits could have deleted file in question,
@ -5154,7 +5160,7 @@ sub git_history {
$ftype = git_get_type($hash); $ftype = git_get_type($hash);
} }
if (!defined $ftype) { if (!defined $ftype) {
die_error(undef, "Unknown type of object"); die_error(500, "Unknown type of object");
} }
my $paging_nav = ''; my $paging_nav = '';
@ -5192,19 +5198,16 @@ sub git_history {
} }
sub git_search { sub git_search {
my ($have_search) = gitweb_check_feature('search'); gitweb_check_feature('search') or die_error(403, "Search is disabled");
if (!$have_search) {
die_error('403 Permission denied', "Permission denied");
}
if (!defined $searchtext) { if (!defined $searchtext) {
die_error(undef, "Text field empty"); die_error(400, "Text field is empty");
} }
if (!defined $hash) { if (!defined $hash) {
$hash = git_get_head_hash($project); $hash = git_get_head_hash($project);
} }
my %co = parse_commit($hash); my %co = parse_commit($hash);
if (!%co) { if (!%co) {
die_error(undef, "Unknown commit object"); die_error(404, "Unknown commit object");
} }
if (!defined $page) { if (!defined $page) {
$page = 0; $page = 0;
@ -5214,16 +5217,12 @@ sub git_search {
if ($searchtype eq 'pickaxe') { if ($searchtype eq 'pickaxe') {
# pickaxe may take all resources of your box and run for several minutes # pickaxe may take all resources of your box and run for several minutes
# with every query - so decide by yourself how public you make this feature # with every query - so decide by yourself how public you make this feature
my ($have_pickaxe) = gitweb_check_feature('pickaxe'); gitweb_check_feature('pickaxe')
if (!$have_pickaxe) { or die_error(403, "Pickaxe is disabled");
die_error('403 Permission denied', "Permission denied");
}
} }
if ($searchtype eq 'grep') { if ($searchtype eq 'grep') {
my ($have_grep) = gitweb_check_feature('grep'); gitweb_check_feature('grep')
if (!$have_grep) { or die_error(403, "Grep is disabled");
die_error('403 Permission denied', "Permission denied");
}
} }
git_header_html(); git_header_html();
@ -5497,7 +5496,7 @@ sub git_feed {
# Atom: http://www.atomenabled.org/developers/syndication/ # Atom: http://www.atomenabled.org/developers/syndication/
# RSS: http://www.notestips.com/80256B3A007F2692/1/NAMO5P9UPQ # RSS: http://www.notestips.com/80256B3A007F2692/1/NAMO5P9UPQ
if ($format ne 'rss' && $format ne 'atom') { if ($format ne 'rss' && $format ne 'atom') {
die_error(undef, "Unknown web feed format"); die_error(400, "Unknown web feed format");
} }
# log/feed of current (HEAD) branch, log of given branch, history of file/directory # log/feed of current (HEAD) branch, log of given branch, history of file/directory