mirror of
https://github.com/postgres/postgres.git
synced 2025-06-26 12:21:12 +03:00
Back-patch addition of ssl_renegotiation_limit into 7.4 through 8.1.
This commit is contained in:
@ -1,5 +1,5 @@
|
||||
<!--
|
||||
$PostgreSQL: pgsql/doc/src/sgml/config.sgml,v 1.36.2.8 2007/04/20 02:38:04 tgl Exp $
|
||||
$PostgreSQL: pgsql/doc/src/sgml/config.sgml,v 1.36.2.9 2010/02/25 23:44:27 tgl Exp $
|
||||
-->
|
||||
<chapter Id="runtime-config">
|
||||
<title>Server Configuration</title>
|
||||
@ -538,6 +538,32 @@ SET ENABLE_SEQSCAN TO OFF;
|
||||
</listitem>
|
||||
</varlistentry>
|
||||
|
||||
<varlistentry id="guc-ssl-renegotiation-limit" xreflabel="ssl_renegotiation_limit">
|
||||
<term><varname>ssl_renegotiation_limit</varname> (<type>int</type>)</term>
|
||||
<indexterm>
|
||||
<primary><varname>ssl_renegotiation_limit</> configuration parameter</primary>
|
||||
</indexterm>
|
||||
<listitem>
|
||||
<para>
|
||||
Specifies how much data can flow over an <acronym>SSL</> encrypted connection
|
||||
before renegotiation of the session will take place. Renegotiation of the
|
||||
session decreases the chance of doing cryptanalysis when large amounts of data
|
||||
are sent, but it also carries a large performance penalty. The sum of
|
||||
sent and received traffic is used to check the limit. If the parameter is
|
||||
set to 0, renegotiation is disabled. The default is <literal>512MB</>.
|
||||
</para>
|
||||
<note>
|
||||
<para>
|
||||
SSL libraries from before November 2009 are insecure when using SSL
|
||||
renegotiation, due to a vulnerability in the SSL protocol. As a stop-gap fix
|
||||
for this vulnerability, some vendors also shipped SSL libraries incapable
|
||||
of doing renegotiation. If any of these libraries are in use on the client
|
||||
or server, SSL renegotiation should be disabled.
|
||||
</para>
|
||||
</note>
|
||||
</listitem>
|
||||
</varlistentry>
|
||||
|
||||
<varlistentry id="guc-password-encryption" xreflabel="password_encryption">
|
||||
<term><varname>password_encryption</varname> (<type>boolean</type>)</term>
|
||||
<indexterm>
|
||||
|
@ -11,7 +11,7 @@
|
||||
*
|
||||
*
|
||||
* IDENTIFICATION
|
||||
* $PostgreSQL: pgsql/src/backend/libpq/be-secure.c,v 1.59.2.5 2009/12/09 06:37:17 mha Exp $
|
||||
* $PostgreSQL: pgsql/src/backend/libpq/be-secure.c,v 1.59.2.6 2010/02/25 23:44:27 tgl Exp $
|
||||
*
|
||||
* Since the server static private key ($DataDir/server.key)
|
||||
* will normally be stored unencrypted so that the database
|
||||
@ -117,13 +117,14 @@ static void close_SSL(Port *);
|
||||
static const char *SSLerrmessage(void);
|
||||
#endif
|
||||
|
||||
#ifdef USE_SSL
|
||||
/*
|
||||
* How much data can be sent across a secure connection
|
||||
* (total in both directions) before we require renegotiation.
|
||||
* Set to 0 to disable renegotiation completely.
|
||||
*/
|
||||
#define RENEGOTIATION_LIMIT (512 * 1024 * 1024)
|
||||
int ssl_renegotiation_limit;
|
||||
|
||||
#ifdef USE_SSL
|
||||
static SSL_CTX *SSL_context = NULL;
|
||||
#endif
|
||||
|
||||
@ -332,7 +333,7 @@ secure_write(Port *port, void *ptr, size_t len)
|
||||
{
|
||||
int err;
|
||||
|
||||
if (port->count > RENEGOTIATION_LIMIT)
|
||||
if (ssl_renegotiation_limit && port->count > ssl_renegotiation_limit * 1024L)
|
||||
{
|
||||
SSL_set_session_id_context(port->ssl, (void *) &SSL_context,
|
||||
sizeof(SSL_context));
|
||||
|
@ -10,7 +10,7 @@
|
||||
* Written by Peter Eisentraut <peter_e@gmx.net>.
|
||||
*
|
||||
* IDENTIFICATION
|
||||
* $PostgreSQL: pgsql/src/backend/utils/misc/guc.c,v 1.299.2.7 2010/01/24 21:49:58 tgl Exp $
|
||||
* $PostgreSQL: pgsql/src/backend/utils/misc/guc.c,v 1.299.2.8 2010/02/25 23:44:27 tgl Exp $
|
||||
*
|
||||
*--------------------------------------------------------------------
|
||||
*/
|
||||
@ -97,6 +97,7 @@ extern int CommitDelay;
|
||||
extern int CommitSiblings;
|
||||
extern char *default_tablespace;
|
||||
extern bool fullPageWrites;
|
||||
extern int ssl_renegotiation_limit;
|
||||
|
||||
#ifdef TRACE_SORT
|
||||
extern bool trace_sort;
|
||||
@ -1500,6 +1501,15 @@ static struct config_int ConfigureNamesInt[] =
|
||||
500, 0, INT_MAX, NULL, NULL
|
||||
},
|
||||
|
||||
{
|
||||
{"ssl_renegotiation_limit", PGC_USERSET, CONN_AUTH_SECURITY,
|
||||
gettext_noop("Set the amount of traffic to send and receive before renegotiating the encryption keys."),
|
||||
NULL
|
||||
},
|
||||
&ssl_renegotiation_limit,
|
||||
512 * 1024, 0, MAX_KILOBYTES, NULL, NULL
|
||||
},
|
||||
|
||||
{
|
||||
{"tcp_keepalives_idle", PGC_USERSET, CLIENT_CONN_OTHER,
|
||||
gettext_noop("Seconds between issuing TCP keepalives."),
|
||||
|
@ -64,6 +64,8 @@
|
||||
|
||||
#authentication_timeout = 60 # 1-600, in seconds
|
||||
#ssl = off
|
||||
#ssl_renegotiation_limit = 524288 # amount of data between renegotiations
|
||||
# in kilobytes
|
||||
#password_encryption = on
|
||||
#db_user_namespace = off
|
||||
|
||||
|
Reference in New Issue
Block a user