LCOV - code coverage report
Current view: top level - src/common - file_perm.c (source / functions) Hit Total Coverage
Test: PostgreSQL 18devel Lines: 14 14 100.0 %
Date: 2025-01-18 04:15:08 Functions: 2 2 100.0 %
Legend: Lines: hit not hit

          Line data    Source code
       1             : /*-------------------------------------------------------------------------
       2             :  *
       3             :  * File and directory permission routines
       4             :  *
       5             :  *
       6             :  * Portions Copyright (c) 1996-2025, PostgreSQL Global Development Group
       7             :  * Portions Copyright (c) 1994, Regents of the University of California
       8             :  *
       9             :  * src/common/file_perm.c
      10             :  *
      11             :  *-------------------------------------------------------------------------
      12             :  */
      13             : #include "c.h"
      14             : 
      15             : #include "common/file_perm.h"
      16             : 
      17             : /* Modes for creating directories and files in the data directory */
      18             : int         pg_dir_create_mode = PG_DIR_MODE_OWNER;
      19             : int         pg_file_create_mode = PG_FILE_MODE_OWNER;
      20             : 
      21             : /*
      22             :  * Mode mask to pass to umask().  This is more of a preventative measure since
      23             :  * all file/directory creates should be performed using the create modes above.
      24             :  */
      25             : int         pg_mode_mask = PG_MODE_MASK_OWNER;
      26             : 
      27             : /*
      28             :  * Set create modes and mask to use when writing to PGDATA based on the data
      29             :  * directory mode passed.  If group read/execute are present in the mode, then
      30             :  * create modes and mask will be relaxed to allow group read/execute on all
      31             :  * newly created files and directories.
      32             :  */
      33             : void
      34        5852 : SetDataDirectoryCreatePerm(int dataDirMode)
      35             : {
      36             :     /* If the data directory mode has group access */
      37        5852 :     if ((PG_DIR_MODE_GROUP & dataDirMode) == PG_DIR_MODE_GROUP)
      38             :     {
      39         334 :         pg_dir_create_mode = PG_DIR_MODE_GROUP;
      40         334 :         pg_file_create_mode = PG_FILE_MODE_GROUP;
      41         334 :         pg_mode_mask = PG_MODE_MASK_GROUP;
      42             :     }
      43             :     /* Else use default permissions */
      44             :     else
      45             :     {
      46        5518 :         pg_dir_create_mode = PG_DIR_MODE_OWNER;
      47        5518 :         pg_file_create_mode = PG_FILE_MODE_OWNER;
      48        5518 :         pg_mode_mask = PG_MODE_MASK_OWNER;
      49             :     }
      50        5852 : }
      51             : 
      52             : #ifdef FRONTEND
      53             : 
      54             : /*
      55             :  * Get the create modes and mask to use when writing to PGDATA by examining the
      56             :  * mode of the PGDATA directory and calling SetDataDirectoryCreatePerm().
      57             :  *
      58             :  * Errors are not handled here and should be reported by the application when
      59             :  * false is returned.
      60             :  *
      61             :  * Suppress when on Windows, because there may not be proper support for Unix-y
      62             :  * file permissions.  But we still run stat() on the directory so that callers
      63             :  * get consistent behavior for example if the directory does not exist.
      64             :  */
      65             : bool
      66        3164 : GetDataDirectoryCreatePerm(const char *dataDir)
      67             : {
      68             :     struct stat statBuf;
      69             : 
      70             :     /*
      71             :      * If an error occurs getting the mode then return false.  The caller is
      72             :      * responsible for generating an error, if appropriate, indicating that we
      73             :      * were unable to access the data directory.
      74             :      */
      75        3164 :     if (stat(dataDir, &statBuf) == -1)
      76          10 :         return false;
      77             : 
      78             : #if !defined(WIN32) && !defined(__CYGWIN__)
      79             :     /* Set permissions */
      80        3154 :     SetDataDirectoryCreatePerm(statBuf.st_mode);
      81             : #endif
      82             : 
      83        3154 :     return true;
      84             : }
      85             : 
      86             : 
      87             : #endif                          /* FRONTEND */

Generated by: LCOV version 1.14