Andrew's git
/
gitweb.git
/ diff
summary
|
log
|
commit
| diff |
tree
commit
grep
author
committer
pickaxe
?
re
git-cvsserver: Improved error handling for pserver
author
Ævar Arnfjörð Bjarmason
<avarab@gmail.com>
Sat, 15 May 2010 02:46:02 +0000
(
02:46
+0000)
committer
Junio C Hamano
<gitster@pobox.com>
Thu, 20 May 2010 04:02:59 +0000
(21:02 -0700)
- Produce an error if the user tries to supply a password for anonymous
- Clarify the error message produced when there's no [gitcvs.authdb]
- Produce an E error if the authdb doesn't exist instead of spewing
$! to the user
- do crypt($user, descramble($pass)) eq $hash; crypt($user, $hash)
eq $hash would accept any password
Signed-off-by: Ævar Arnfjörð Bjarmason <avarab@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
git-cvsserver.perl
patch
|
blob
|
history
raw
|
patch
|
inline
| side by side (parent:
3052525
)
diff --git
a/git-cvsserver.perl
b/git-cvsserver.perl
index ed1d5b9d6010797e507ebebce08dd9ed9a0a3b59..3833beeef38c35bf5da0407e89a959874a253307 100755
(executable)
--- a/
git-cvsserver.perl
+++ b/
git-cvsserver.perl
@@
-187,19
+187,37
@@
$line = <STDIN>; chomp $line;
my $password = $line;
$line = <STDIN>; chomp $line;
my $password = $line;
- unless ($user eq 'anonymous') {
+ if ($user eq 'anonymous') {
+ # "A" will be 1 byte, use length instead in case the
+ # encryption method ever changes (yeah, right!)
+ if (length($password) > 1 ) {
+ print "E Don't supply a password for the `anonymous' user\n";
+ print "I HATE YOU\n";
+ exit 1;
+ }
+
+ # Fall through to LOVE
+ } else {
# Trying to authenticate a user
if (not exists $cfg->{gitcvs}->{authdb}) {
# Trying to authenticate a user
if (not exists $cfg->{gitcvs}->{authdb}) {
- print "E the repo config file needs a [gitcvs.authdb] section with a filename\n";
+ print "E the repo config file needs a [gitcvs] section with an 'authdb' parameter set to the filename of the authentication database\n";
+ print "I HATE YOU\n";
+ exit 1;
+ }
+
+ my $authdb = $cfg->{gitcvs}->{authdb};
+
+ unless (-e $authdb) {
+ print "E The authentication database specified in [gitcvs.authdb] does not exist\n";
print "I HATE YOU\n";
exit 1;
}
my $auth_ok;
print "I HATE YOU\n";
exit 1;
}
my $auth_ok;
- open my $passwd, "<", $
cfg->{gitcvs}->{authdb}
or die $!;
+ open my $passwd, "<", $
authdb
or die $!;
while (<$passwd>) {
if (m{^\Q$user\E:(.*)}) {
while (<$passwd>) {
if (m{^\Q$user\E:(.*)}) {
- if (crypt($user,
$1
) eq $1) {
+ if (crypt($user,
descramble($password)
) eq $1) {
$auth_ok = 1;
}
};
$auth_ok = 1;
}
};
@@
-210,7
+228,8
@@
print "I HATE YOU\n";
exit 1;
}
print "I HATE YOU\n";
exit 1;
}
- # else fall through to LOVE
+
+ # Fall through to LOVE
}
# For checking whether the user is anonymous on commit
}
# For checking whether the user is anonymous on commit