LCOV - code coverage report
Current view: top level - src/interfaces/libpq - fe-gssapi-common.c (source / functions) Coverage Total Hit
Test: Code coverage Lines: 0.0 % 59 0
Test Date: 2026-01-26 10:56:24 Functions: 0.0 % 4 0
Legend: Lines:     hit not hit
Branches: + taken - not taken # not executed
Branches: 0.0 % 16 0

             Branch data     Line data    Source code
       1                 :             : /*-------------------------------------------------------------------------
       2                 :             :  *
       3                 :             :  * fe-gssapi-common.c
       4                 :             :  *     The front-end (client) GSSAPI common code
       5                 :             :  *
       6                 :             :  * Portions Copyright (c) 1996-2026, PostgreSQL Global Development Group
       7                 :             :  * Portions Copyright (c) 1994, Regents of the University of California
       8                 :             :  *
       9                 :             :  * IDENTIFICATION
      10                 :             :  *      src/interfaces/libpq/fe-gssapi-common.c
      11                 :             :  *-------------------------------------------------------------------------
      12                 :             :  */
      13                 :             : 
      14                 :             : #include "postgres_fe.h"
      15                 :             : 
      16                 :             : #include "fe-gssapi-common.h"
      17                 :             : 
      18                 :             : #include "libpq-int.h"
      19                 :             : #include "pqexpbuffer.h"
      20                 :             : 
      21                 :             : /*
      22                 :             :  * Fetch all errors of a specific type and append to "str".
      23                 :             :  * Each error string is preceded by a space.
      24                 :             :  */
      25                 :             : static void
      26                 :           0 : pg_GSS_error_int(PQExpBuffer str, OM_uint32 stat, int type)
      27                 :             : {
      28                 :           0 :         OM_uint32       lmin_s;
      29                 :           0 :         gss_buffer_desc lmsg;
      30                 :           0 :         OM_uint32       msg_ctx = 0;
      31                 :             : 
      32                 :           0 :         do
      33                 :             :         {
      34                 :           0 :                 if (gss_display_status(&lmin_s, stat, type, GSS_C_NO_OID,
      35         [ #  # ]:           0 :                                                            &msg_ctx, &lmsg) != GSS_S_COMPLETE)
      36                 :           0 :                         break;
      37                 :           0 :                 appendPQExpBufferChar(str, ' ');
      38                 :           0 :                 appendBinaryPQExpBuffer(str, lmsg.value, lmsg.length);
      39                 :           0 :                 gss_release_buffer(&lmin_s, &lmsg);
      40         [ #  # ]:           0 :         } while (msg_ctx);
      41                 :           0 : }
      42                 :             : 
      43                 :             : /*
      44                 :             :  * GSSAPI errors contain two parts; put both into conn->errorMessage.
      45                 :             :  */
      46                 :             : void
      47                 :           0 : pg_GSS_error(const char *mprefix, PGconn *conn,
      48                 :             :                          OM_uint32 maj_stat, OM_uint32 min_stat)
      49                 :             : {
      50                 :           0 :         appendPQExpBuffer(&conn->errorMessage, "%s:", mprefix);
      51                 :           0 :         pg_GSS_error_int(&conn->errorMessage, maj_stat, GSS_C_GSS_CODE);
      52                 :           0 :         appendPQExpBufferChar(&conn->errorMessage, ':');
      53                 :           0 :         pg_GSS_error_int(&conn->errorMessage, min_stat, GSS_C_MECH_CODE);
      54                 :           0 :         appendPQExpBufferChar(&conn->errorMessage, '\n');
      55                 :           0 : }
      56                 :             : 
      57                 :             : /*
      58                 :             :  * Check if we can acquire credentials at all (and yield them if so).
      59                 :             :  */
      60                 :             : bool
      61                 :           0 : pg_GSS_have_cred_cache(gss_cred_id_t *cred_out)
      62                 :             : {
      63                 :           0 :         OM_uint32       major,
      64                 :             :                                 minor;
      65                 :           0 :         gss_cred_id_t cred = GSS_C_NO_CREDENTIAL;
      66                 :             : 
      67                 :           0 :         major = gss_acquire_cred(&minor, GSS_C_NO_NAME, 0, GSS_C_NO_OID_SET,
      68                 :             :                                                          GSS_C_INITIATE, &cred, NULL, NULL);
      69         [ #  # ]:           0 :         if (major != GSS_S_COMPLETE)
      70                 :             :         {
      71                 :           0 :                 *cred_out = NULL;
      72                 :           0 :                 return false;
      73                 :             :         }
      74                 :           0 :         *cred_out = cred;
      75                 :           0 :         return true;
      76                 :           0 : }
      77                 :             : 
      78                 :             : /*
      79                 :             :  * Try to load service name for a connection
      80                 :             :  */
      81                 :             : int
      82                 :           0 : pg_GSS_load_servicename(PGconn *conn)
      83                 :             : {
      84                 :           0 :         OM_uint32       maj_stat,
      85                 :             :                                 min_stat;
      86                 :           0 :         int                     maxlen;
      87                 :           0 :         gss_buffer_desc temp_gbuf;
      88                 :           0 :         char       *host;
      89                 :             : 
      90         [ #  # ]:           0 :         if (conn->gtarg_nam != NULL)
      91                 :             :                 /* Already taken care of - move along */
      92                 :           0 :                 return STATUS_OK;
      93                 :             : 
      94                 :           0 :         host = PQhost(conn);
      95   [ #  #  #  # ]:           0 :         if (!(host && host[0] != '\0'))
      96                 :             :         {
      97                 :           0 :                 libpq_append_conn_error(conn, "host name must be specified");
      98                 :           0 :                 return STATUS_ERROR;
      99                 :             :         }
     100                 :             : 
     101                 :             :         /*
     102                 :             :          * Import service principal name so the proper ticket can be acquired by
     103                 :             :          * the GSSAPI system.
     104                 :             :          */
     105                 :           0 :         maxlen = strlen(conn->krbsrvname) + strlen(host) + 2;
     106                 :           0 :         temp_gbuf.value = (char *) malloc(maxlen);
     107         [ #  # ]:           0 :         if (!temp_gbuf.value)
     108                 :             :         {
     109                 :           0 :                 libpq_append_conn_error(conn, "out of memory");
     110                 :           0 :                 return STATUS_ERROR;
     111                 :             :         }
     112                 :           0 :         snprintf(temp_gbuf.value, maxlen, "%s@%s",
     113                 :           0 :                          conn->krbsrvname, host);
     114                 :           0 :         temp_gbuf.length = strlen(temp_gbuf.value);
     115                 :             : 
     116                 :           0 :         maj_stat = gss_import_name(&min_stat, &temp_gbuf,
     117                 :           0 :                                                            GSS_C_NT_HOSTBASED_SERVICE, &conn->gtarg_nam);
     118                 :           0 :         free(temp_gbuf.value);
     119                 :             : 
     120         [ #  # ]:           0 :         if (maj_stat != GSS_S_COMPLETE)
     121                 :             :         {
     122                 :           0 :                 pg_GSS_error(libpq_gettext("GSSAPI name import error"),
     123                 :           0 :                                          conn,
     124                 :           0 :                                          maj_stat, min_stat);
     125                 :           0 :                 return STATUS_ERROR;
     126                 :             :         }
     127                 :           0 :         return STATUS_OK;
     128                 :           0 : }
        

Generated by: LCOV version 2.3.2-1