28 lines
863 B
Diff
28 lines
863 B
Diff
|
Use what NSS considers default for DEFAULT cipher string.
|
||
|
|
||
|
Author: Matus Honek <mhonek@redhat.com>
|
||
|
Resolves: #1387868
|
||
|
Backports: #1245279 #1300701
|
||
|
|
||
|
diff --git a/libraries/libldap/tls_m.c b/libraries/libldap/tls_m.c
|
||
|
--- a/libraries/libldap/tls_m.c
|
||
|
+++ b/libraries/libldap/tls_m.c
|
||
|
@@ -645,7 +645,16 @@ nss_parse_ciphers(const char *cipherstr, int cipher_list[ciphernum])
|
||
|
}
|
||
|
} else if (!strcmp(cipher, "DEFAULT")) {
|
||
|
for (i=0; i<ciphernum; i++) {
|
||
|
- cipher_list[i] = ciphers_def[i].enabled == SSL_ALLOWED ? 1 : 0;
|
||
|
+ PRBool enabled;
|
||
|
+ if (SSL_CipherPrefGetDefault(ciphers_def[i].num, &enabled) == SECSuccess) {
|
||
|
+ if (!(ciphers_def[i].attr & SSL_eNULL)) {
|
||
|
+ cipher_list[i] = enabled == SSL_ALLOWED ? 1 : 0;
|
||
|
+ } else {
|
||
|
+ cipher_list[i] = -1;
|
||
|
+ }
|
||
|
+ } else {
|
||
|
+ cipher_list[i] = -1;
|
||
|
+ }
|
||
|
}
|
||
|
} else {
|
||
|
int mask = 0;
|