openldap-nss-certs-from-certdb-fallback-pem.patch 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. MozNSS: load certificates from certdb, fallback to PEM
  2. If TLS_CACERT pointed to a PEM file and TLS_CACERTDIR was set to NSS
  3. certificate database, the backend assumed that the certificate is always
  4. located in the certificate database. This assumption might be wrong.
  5. This patch makes the library to try to load the certificate from NSS
  6. database and fallback to PEM file if unsuccessfull.
  7. Author: Jan Vcelak <jvcelak@redhat.com>
  8. Upstream ITS: #7389
  9. Resolves: #857455
  10. diff --git a/libraries/libldap/tls_m.c b/libraries/libldap/tls_m.c
  11. index 6847bea..8339391 100644
  12. --- a/libraries/libldap/tls_m.c
  13. +++ b/libraries/libldap/tls_m.c
  14. @@ -1412,7 +1412,7 @@ tlsm_ctx_load_private_key( tlsm_ctx *ctx )
  15. /* prefer unlocked key, then key from opened certdb, then any other */
  16. if ( unlocked_key )
  17. ctx->tc_private_key = unlocked_key;
  18. - else if ( ctx->tc_certdb_slot )
  19. + else if ( ctx->tc_certdb_slot && !ctx->tc_using_pem )
  20. ctx->tc_private_key = PK11_FindKeyByDERCert( ctx->tc_certdb_slot, ctx->tc_certificate, pin_arg );
  21. else
  22. ctx->tc_private_key = PK11_FindKeyByAnyCert( ctx->tc_certificate, pin_arg );
  23. @@ -1909,8 +1909,6 @@ tlsm_deferred_init( void *arg )
  24. }
  25. return -1;
  26. }
  27. -
  28. - ctx->tc_using_pem = PR_TRUE;
  29. }
  30. NSS_SetDomesticPolicy();
  31. @@ -2363,15 +2361,9 @@ tlsm_deferred_ctx_init( void *arg )
  32. /* set up our cert and key, if any */
  33. if ( lt->lt_certfile ) {
  34. - /* if using the PEM module, load the PEM file specified by lt_certfile */
  35. - /* otherwise, assume this is the name of a cert already in the db */
  36. - if ( ctx->tc_using_pem ) {
  37. - /* this sets ctx->tc_certificate to the correct value */
  38. - int rc = tlsm_add_cert_from_file( ctx, lt->lt_certfile, PR_FALSE );
  39. - if ( rc ) {
  40. - return rc;
  41. - }
  42. - } else {
  43. +
  44. + /* first search in certdb (lt_certfile is nickname) */
  45. + if ( ctx->tc_certdb ) {
  46. char *tmp_certname;
  47. if ( tlsm_is_tokenname_certnick( lt->lt_certfile )) {
  48. @@ -2391,8 +2383,31 @@ tlsm_deferred_ctx_init( void *arg )
  49. Debug( LDAP_DEBUG_ANY,
  50. "TLS: error: the certificate '%s' could not be found in the database - error %d:%s.\n",
  51. lt->lt_certfile, errcode, PR_ErrorToString( errcode, PR_LANGUAGE_I_DEFAULT ) );
  52. + }
  53. + }
  54. +
  55. + /* fallback to PEM module (lt_certfile is filename) */
  56. + if ( !ctx->tc_certificate ) {
  57. + if ( !pem_module && tlsm_init_pem_module() ) {
  58. + int pem_errcode = PORT_GetError();
  59. + Debug( LDAP_DEBUG_ANY,
  60. + "TLS: fallback to PEM impossible, module cannot be loaded - error %d:%s.\n",
  61. + pem_errcode, PR_ErrorToString( pem_errcode, PR_LANGUAGE_I_DEFAULT ), 0 );
  62. return -1;
  63. }
  64. +
  65. + /* this sets ctx->tc_certificate to the correct value */
  66. + if ( !tlsm_add_cert_from_file( ctx, lt->lt_certfile, PR_FALSE ) ) {
  67. + ctx->tc_using_pem = PR_TRUE;
  68. + }
  69. + }
  70. +
  71. + if ( ctx->tc_certificate ) {
  72. + Debug( LDAP_DEBUG_ANY,
  73. + "TLS: certificate '%s' successfully loaded from %s.\n", lt->lt_certfile,
  74. + ctx->tc_using_pem ? "PEM file" : "moznss database", 0);
  75. + } else {
  76. + return -1;
  77. }
  78. }