• Michael Paquier's avatar
    Add some information about authenticated identity via log_connections · 9afffcb8
    Michael Paquier authored
    The "authenticated identity" is the string used by an authentication
    method to identify a particular user.  In many common cases, this is the
    same as the PostgreSQL username, but for some third-party authentication
    methods, the identifier in use may be shortened or otherwise translated
    (e.g. through pg_ident user mappings) before the server stores it.
    
    To help administrators see who has actually interacted with the system,
    this commit adds the capability to store the original identity when
    authentication succeeds within the backend's Port, and generates a log
    entry when log_connections is enabled.  The log entries generated look
    something like this (where a local user named "foouser" is connecting to
    the database as the database user called "admin"):
    
      LOG:  connection received: host=[local]
      LOG:  connection authenticated: identity="foouser" method=peer (/data/pg_hba.conf:88)
      LOG:  connection authorized: user=admin database=postgres application_name=psql
    
    Port->authn_id is set according to the authentication method:
    
      bsd: the PostgreSQL username (aka the local username)
      cert: the client's Subject DN
      gss: the user principal
      ident: the remote username
      ldap: the final bind DN
      pam: the PostgreSQL username (aka PAM username)
      password (and all pw-challenge methods): the PostgreSQL username
      peer: the peer's pw_name
      radius: the PostgreSQL username (aka the RADIUS username)
      sspi: either the down-level (SAM-compatible) logon name, if
            compat_realm=1, or the User Principal Name if compat_realm=0
    
    The trust auth method does not set an authenticated identity.  Neither
    does clientcert=verify-full.
    
    Port->authn_id could be used for other purposes, like a superuser-only
    extra column in pg_stat_activity, but this is left as future work.
    
    PostgresNode::connect_{ok,fails}() have been modified to let tests check
    the backend log files for required or prohibited patterns, using the
    new log_like and log_unlike parameters.  This uses a method based on a
    truncation of the existing server log file, like issues_sql_like().
    Tests are added to the ldap, kerberos, authentication and SSL test
    suites.
    
    Author: Jacob Champion
    Reviewed-by: Stephen Frost, Magnus Hagander, Tom Lane, Michael Paquier
    Discussion: https://postgr.es/m/c55788dd1773c521c862e8e0dddb367df51222be.camel@vmware.com
    9afffcb8
PostgresNode.pm 60.9 KB