aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2012-05-30 10:53:44 -0400
committerTom Lane <tgl@sss.pgh.pa.us>2012-05-30 10:53:44 -0400
commit4c95cdabce4993c7c016b664dac73c5c7ed9770b (patch)
tree66a67eb6eba6cf724f57412c4e5ad7b0095b1757
parent66cad2d7b4e08bcad61507d50b9640b814c16b34 (diff)
downloadpostgresql-4c95cdabce4993c7c016b664dac73c5c7ed9770b.tar.gz
postgresql-4c95cdabce4993c7c016b664dac73c5c7ed9770b.zip
Fix incorrect password transformation in contrib/pgcrypto's DES crypt().
Overly tight coding caused the password transformation loop to stop examining input once it had processed a byte equal to 0x80. Thus, if the given password string contained such a byte (which is possible though not highly likely in UTF8, and perhaps also in other non-ASCII encodings), all subsequent characters would not contribute to the hash, making the password much weaker than it appears on the surface. This would only affect cases where applications used DES crypt() to encode passwords before storing them in the database. If a weak password has been created in this fashion, the hash will stop matching after this update has been applied, so it will be easy to tell if any passwords were unexpectedly weak. Changing to a different password would be a good idea in such a case. (Since DES has been considered inadequately secure for some time, changing to a different encryption algorithm can also be recommended.) This code, and the bug, are shared with at least PHP, FreeBSD, and OpenBSD. Since the other projects have already published their fixes, there is no point in trying to keep this commit private. This bug has been assigned CVE-2012-2143, and credit for its discovery goes to Rubin Xu and Joseph Bonneau.
-rw-r--r--contrib/pgcrypto/crypt-des.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/contrib/pgcrypto/crypt-des.c b/contrib/pgcrypto/crypt-des.c
index a907626d398..0337bfcd4ba 100644
--- a/contrib/pgcrypto/crypt-des.c
+++ b/contrib/pgcrypto/crypt-des.c
@@ -671,7 +671,8 @@ px_crypt_des(const char *key, const char *setting)
q = (uint8 *) keybuf;
while (q - (uint8 *) keybuf - 8)
{
- if ((*q++ = *key << 1))
+ *q++ = *key << 1;
+ if (*key != '\0')
key++;
}
if (des_setkey((char *) keybuf))