]> granicus.if.org Git - postgresql/commitdiff
Remove notes from the frontend SSL source that are incorrect or
authorMagnus Hagander <magnus@hagander.net>
Fri, 24 Oct 2008 12:29:11 +0000 (12:29 +0000)
committerMagnus Hagander <magnus@hagander.net>
Fri, 24 Oct 2008 12:29:11 +0000 (12:29 +0000)
end-user documentation that lives in the actual documentation.

src/interfaces/libpq/fe-secure.c

index 2f72b0a5de4d8b8bd99296b36207e138acf3779d..af85257a86bcb2b07b43e4e45d24186268b76e64 100644 (file)
  *
  *
  * IDENTIFICATION
- *       $PostgreSQL: pgsql/src/interfaces/libpq/fe-secure.c,v 1.105 2008/05/16 18:30:53 mha Exp $
+ *       $PostgreSQL: pgsql/src/interfaces/libpq/fe-secure.c,v 1.106 2008/10/24 12:29:11 mha Exp $
  *
  * NOTES
- *       [ Most of these notes are wrong/obsolete, but perhaps not all ]
- *
- *       The client *requires* a valid server certificate.  Since
- *       SSH tunnels provide anonymous confidentiality, the presumption
- *       is that sites that want endpoint authentication will use the
- *       direct SSL support, while sites that are comfortable with
- *       anonymous connections will use SSH tunnels.
- *
- *       This code verifies the server certificate, to detect simple
- *       "man-in-the-middle" and "impersonation" attacks.      The
- *       server certificate, or better yet the CA certificate used
- *       to sign the server certificate, should be present in the
- *       "~/.postgresql/root.crt" file.  If this file isn't
- *       readable, or the server certificate can't be validated,
- *       pqsecure_open_client() will return an error code.
- *
- *       Additionally, the server certificate's "common name" must
- *       resolve to the other end of the socket.  This makes it
- *       substantially harder to pull off a "man-in-the-middle" or
- *       "impersonation" attack even if the server's private key
- *       has been stolen.      This check limits acceptable network
- *       layers to Unix sockets (weird, but legal), TCPv4 and TCPv6.
- *
- *       Unfortunately neither the current front- or back-end handle
- *       failure gracefully, resulting in the backend hiccupping.
- *       This points out problems in each (the frontend shouldn't even
- *       try to do SSL if pqsecure_initialize() fails, and the backend
- *       shouldn't crash/recover if an SSH negotiation fails.  The
- *       backend definitely needs to be fixed, to prevent a "denial
- *       of service" attack, but I don't know enough about how the
- *       backend works (especially that pre-SSL negotiation) to identify
- *       a fix.
- *
- *       ...
- *
- *       Unlike the server's static private key, the client's
- *       static private key (~/.postgresql/postgresql.key)
- *       should normally be stored encrypted.  However we still
- *       support EPH since it's useful for other reasons.
- *
- *       ...
- *
- *       Client certificates are supported, if the server requests
- *       or requires them.  Client certificates can be used for
- *       authentication, to prevent sessions from being hijacked,
- *       or to allow "road warriors" to access the database while
- *       keeping it closed to everyone else.
- *
- *       The user's certificate and private key are located in
- *             ~/.postgresql/postgresql.crt
- *       and
- *             ~/.postgresql/postgresql.key
- *       respectively.
- *
- *       ...
  *
  *       We don't provide informational callbacks here (like
  *       info_cb() in be-secure.c), since there's mechanism to