Simplify ssl_add_cert_chain logic.
authorDr. Stephen Henson <steve@openssl.org>
Sun, 9 Mar 2014 16:12:20 +0000 (16:12 +0000)
committerDr. Stephen Henson <steve@openssl.org>
Mon, 10 Mar 2014 15:47:33 +0000 (15:47 +0000)
ssl/ssl_cert.c

index 2c66460fe43c490db26ae327d374035d3df1b93a..fd59158128cfc44a43c04e3e290ce43b6cae41e0 100644 (file)
@@ -1113,81 +1113,74 @@ static int ssl_add_cert_to_buf(BUF_MEM *buf, unsigned long *l, X509 *x)
 int ssl_add_cert_chain(SSL *s, CERT_PKEY *cpk, unsigned long *l)
        {
        BUF_MEM *buf = s->init_buf;
-       int no_chain;
        int i;
 
        X509 *x;
        STACK_OF(X509) *extra_certs;
        X509_STORE *chain_store;
 
-       if (cpk)
-               x = cpk->x509;
-       else
-               x = NULL;
+       /* TLSv1 sends a chain with nothing in it, instead of an alert */
+       if (!BUF_MEM_grow_clean(buf,10))
+               {
+               SSLerr(SSL_F_SSL_ADD_CERT_CHAIN,ERR_R_BUF_LIB);
+               return 0;
+               }
 
-       if (s->cert->chain_store)
-               chain_store = s->cert->chain_store;
-       else
-               chain_store = s->ctx->cert_store;
+       if (!cpk || !cpk->x509)
+               return 1;
+
+       x = cpk->x509;
 
        /* If we have a certificate specific chain use it, else use
         * parent ctx.
         */
-       if (cpk && cpk->chain)
+       if (cpk->chain)
                extra_certs = cpk->chain;
        else
                extra_certs = s->ctx->extra_certs;
 
        if ((s->mode & SSL_MODE_NO_AUTO_CHAIN) || extra_certs)
-               no_chain = 1;
+               chain_store = NULL;
+       else if (s->cert->chain_store)
+               chain_store = s->cert->chain_store;
        else
-               no_chain = 0;
+               chain_store = s->ctx->cert_store;
 
-       /* TLSv1 sends a chain with nothing in it, instead of an alert */
-       if (!BUF_MEM_grow_clean(buf,10))
-               {
-               SSLerr(SSL_F_SSL_ADD_CERT_CHAIN,ERR_R_BUF_LIB);
-               return 0;
-               }
-       if (x != NULL)
+       if (chain_store)
                {
-               if (no_chain)
+               X509_STORE_CTX xs_ctx;
+
+               if (!X509_STORE_CTX_init(&xs_ctx,chain_store,x,NULL))
                        {
-                       if (!ssl_add_cert_to_buf(buf, l, x))
-                               return 0;
+                       SSLerr(SSL_F_SSL_ADD_CERT_CHAIN,ERR_R_X509_LIB);
+                       return(0);
                        }
-               else
+               X509_verify_cert(&xs_ctx);
+               /* Don't leave errors in the queue */
+               ERR_clear_error();
+               for (i=0; i < sk_X509_num(xs_ctx.chain); i++)
                        {
-                       X509_STORE_CTX xs_ctx;
+                       x = sk_X509_value(xs_ctx.chain, i);
 
-                       if (!X509_STORE_CTX_init(&xs_ctx,chain_store,x,NULL))
-                               {
-                               SSLerr(SSL_F_SSL_ADD_CERT_CHAIN,ERR_R_X509_LIB);
-                               return(0);
-                               }
-                       X509_verify_cert(&xs_ctx);
-                       /* Don't leave errors in the queue */
-                       ERR_clear_error();
-                       for (i=0; i < sk_X509_num(xs_ctx.chain); i++)
+                       if (!ssl_add_cert_to_buf(buf, l, x))
                                {
-                               x = sk_X509_value(xs_ctx.chain, i);
-
-                               if (!ssl_add_cert_to_buf(buf, l, x))
-                                       {
-                                       X509_STORE_CTX_cleanup(&xs_ctx);
-                                       return 0;
-                                       }
+                               X509_STORE_CTX_cleanup(&xs_ctx);
+                               return 0;
                                }
-                       X509_STORE_CTX_cleanup(&xs_ctx);
                        }
+               X509_STORE_CTX_cleanup(&xs_ctx);
                }
-       for (i=0; i<sk_X509_num(extra_certs); i++)
+       else
                {
-               x=sk_X509_value(extra_certs,i);
                if (!ssl_add_cert_to_buf(buf, l, x))
                        return 0;
+               for (i=0; i<sk_X509_num(extra_certs); i++)
+                       {
+                       x=sk_X509_value(extra_certs,i);
+                       if (!ssl_add_cert_to_buf(buf, l, x))
+                               return 0;
+                       }
                }
-
        return 1;
        }