Blame SOURCES/httpd-2.4.6-r1825120.patch

008793
diff --git a/modules/ssl/ssl_engine_init.c b/modules/ssl/ssl_engine_init.c
008793
index 57b76c0..814ec4f 100644
008793
--- a/modules/ssl/ssl_engine_init.c
008793
+++ b/modules/ssl/ssl_engine_init.c
008793
@@ -1522,70 +1522,18 @@ void ssl_init_CheckServers(SSLModConfigRec *mc, server_rec *base_server, apr_poo
008793
     }
008793
 }
008793
 
008793
-static int ssl_init_FindCAList_X509NameCmp(const X509_NAME * const *a,
008793
-                                           const X509_NAME * const *b)
008793
-{
008793
-    return(X509_NAME_cmp(*a, *b));
008793
-}
008793
-
008793
-static void ssl_init_PushCAList(STACK_OF(X509_NAME) *ca_list,
008793
-                                server_rec *s, apr_pool_t *ptemp,
008793
-                                const char *file)
008793
-{
008793
-    int n;
008793
-    STACK_OF(X509_NAME) *sk;
008793
-
008793
-    sk = (STACK_OF(X509_NAME) *)
008793
-             SSL_load_client_CA_file(file);
008793
-
008793
-    if (!sk) {
008793
-        return;
008793
-    }
008793
-
008793
-    for (n = 0; n < sk_X509_NAME_num(sk); n++) {
008793
-        X509_NAME *name = sk_X509_NAME_value(sk, n);
008793
-
008793
-        ap_log_error(APLOG_MARK, APLOG_DEBUG, 0, s, APLOGNO(02209)
008793
-                     "CA certificate: %s",
008793
-                     SSL_X509_NAME_to_string(ptemp, name, 0));
008793
-
008793
-        /*
008793
-         * note that SSL_load_client_CA_file() checks for duplicates,
008793
-         * but since we call it multiple times when reading a directory
008793
-         * we must also check for duplicates ourselves.
008793
-         */
008793
-
008793
-        if (sk_X509_NAME_find(ca_list, name) < 0) {
008793
-            /* this will be freed when ca_list is */
008793
-            sk_X509_NAME_push(ca_list, name);
008793
-        }
008793
-        else {
008793
-            /* need to free this ourselves, else it will leak */
008793
-            X509_NAME_free(name);
008793
-        }
008793
-    }
008793
-
008793
-    sk_X509_NAME_free(sk);
008793
-}
008793
-
008793
 STACK_OF(X509_NAME) *ssl_init_FindCAList(server_rec *s,
008793
                                          apr_pool_t *ptemp,
008793
                                          const char *ca_file,
008793
                                          const char *ca_path)
008793
 {
008793
-    STACK_OF(X509_NAME) *ca_list;
008793
-
008793
-    /*
008793
-     * Start with a empty stack/list where new
008793
-     * entries get added in sorted order.
008793
-     */
008793
-    ca_list = sk_X509_NAME_new(ssl_init_FindCAList_X509NameCmp);
008793
+    STACK_OF(X509_NAME) *ca_list = sk_X509_NAME_new_null();;
008793
 
008793
     /*
008793
      * Process CA certificate bundle file
008793
      */
008793
     if (ca_file) {
008793
-        ssl_init_PushCAList(ca_list, s, ptemp, ca_file);
008793
+        SSL_add_file_cert_subjects_to_stack(ca_list, ca_file);
008793
         /*
008793
          * If ca_list is still empty after trying to load ca_file
008793
          * then the file failed to load, and users should hear about that.
008793
@@ -1619,17 +1567,12 @@ STACK_OF(X509_NAME) *ssl_init_FindCAList(server_rec *s,
008793
                 continue; /* don't try to load directories */
008793
             }
008793
             file = apr_pstrcat(ptemp, ca_path, "/", direntry.name, NULL);
008793
-            ssl_init_PushCAList(ca_list, s, ptemp, file);
008793
+            SSL_add_file_cert_subjects_to_stack(ca_list, file);
008793
         }
008793
 
008793
         apr_dir_close(dir);
008793
     }
008793
 
008793
-    /*
008793
-     * Cleanup
008793
-     */
008793
-    (void) sk_X509_NAME_set_cmp_func(ca_list, NULL);
008793
-
008793
     return ca_list;
008793
 }
008793