mirror of
https://git.postgresql.org/git/postgresql.git
synced 2024-12-27 08:39:28 +08:00
Don't require pqGetHomeDirectory to succeed if the user has specified
hardcoded paths for SSL rootcert/crl/clientcert/key. As noted by Andrew Chernow
This commit is contained in:
parent
16785db18c
commit
75eafe965e
@ -11,7 +11,7 @@
|
|||||||
*
|
*
|
||||||
*
|
*
|
||||||
* IDENTIFICATION
|
* IDENTIFICATION
|
||||||
* $PostgreSQL: pgsql/src/interfaces/libpq/fe-secure.c,v 1.115 2009/01/01 17:24:03 momjian Exp $
|
* $PostgreSQL: pgsql/src/interfaces/libpq/fe-secure.c,v 1.116 2009/01/07 12:02:46 mha Exp $
|
||||||
*
|
*
|
||||||
* NOTES
|
* NOTES
|
||||||
*
|
*
|
||||||
@ -560,12 +560,19 @@ client_cert_cb(SSL *ssl, X509 **x509, EVP_PKEY **pkey)
|
|||||||
PGconn *conn = (PGconn *) SSL_get_app_data(ssl);
|
PGconn *conn = (PGconn *) SSL_get_app_data(ssl);
|
||||||
char sebuf[256];
|
char sebuf[256];
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If conn->sslcert or conn->sslkey is not set, we don't need the home
|
||||||
|
* directory to find the required files.
|
||||||
|
*/
|
||||||
|
if (!conn->sslcert || !conn->sslkey)
|
||||||
|
{
|
||||||
if (!pqGetHomeDirectory(homedir, sizeof(homedir)))
|
if (!pqGetHomeDirectory(homedir, sizeof(homedir)))
|
||||||
{
|
{
|
||||||
printfPQExpBuffer(&conn->errorMessage,
|
printfPQExpBuffer(&conn->errorMessage,
|
||||||
libpq_gettext("could not get user information\n"));
|
libpq_gettext("cannot find home directory to locate client certificate files"));
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* read the user certificate */
|
/* read the user certificate */
|
||||||
if (conn->sslcert)
|
if (conn->sslcert)
|
||||||
@ -964,11 +971,30 @@ initialize_SSL(PGconn *conn)
|
|||||||
* If sslverify is set to anything other than "none", perform certificate
|
* If sslverify is set to anything other than "none", perform certificate
|
||||||
* verification. If set to "cn" we will also do further verifications after
|
* verification. If set to "cn" we will also do further verifications after
|
||||||
* the connection has been completed.
|
* the connection has been completed.
|
||||||
|
*
|
||||||
|
* If we are going to look for either root certificate or CRL in the home directory,
|
||||||
|
* we need pqGetHomeDirectory() to succeed. In other cases, we don't need to
|
||||||
|
* get the home directory explicitly.
|
||||||
*/
|
*/
|
||||||
|
if (!conn->sslrootcert || !conn->sslcrl)
|
||||||
/* Set up to verify server cert, if root.crt is present */
|
|
||||||
if (pqGetHomeDirectory(homedir, sizeof(homedir)))
|
|
||||||
{
|
{
|
||||||
|
if (!pqGetHomeDirectory(homedir, sizeof(homedir)))
|
||||||
|
{
|
||||||
|
if (strcmp(conn->sslverify, "none") != 0)
|
||||||
|
{
|
||||||
|
printfPQExpBuffer(&conn->errorMessage,
|
||||||
|
libpq_gettext("cannot find home directory to locate root certificate file"));
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
homedir[0] = '\0';
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (conn->sslrootcert)
|
if (conn->sslrootcert)
|
||||||
strncpy(fnbuf, conn->sslrootcert, sizeof(fnbuf));
|
strncpy(fnbuf, conn->sslrootcert, sizeof(fnbuf));
|
||||||
else
|
else
|
||||||
@ -1017,7 +1043,7 @@ initialize_SSL(PGconn *conn)
|
|||||||
}
|
}
|
||||||
|
|
||||||
SSL_CTX_set_verify(SSL_context, SSL_VERIFY_PEER, verify_cb);
|
SSL_CTX_set_verify(SSL_context, SSL_VERIFY_PEER, verify_cb);
|
||||||
}
|
} /* root certificate exists */
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (strcmp(conn->sslverify, "none") != 0)
|
if (strcmp(conn->sslverify, "none") != 0)
|
||||||
@ -1027,16 +1053,6 @@ initialize_SSL(PGconn *conn)
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (strcmp(conn->sslverify, "none") != 0)
|
|
||||||
{
|
|
||||||
printfPQExpBuffer(&conn->errorMessage,
|
|
||||||
libpq_gettext("cannot find home directory to locate root certificate file"));
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* set up mechanism to provide client certificate, if available */
|
/* set up mechanism to provide client certificate, if available */
|
||||||
SSL_CTX_set_client_cert_cb(SSL_context, client_cert_cb);
|
SSL_CTX_set_client_cert_cb(SSL_context, client_cert_cb);
|
||||||
|
Loading…
Reference in New Issue
Block a user