mirror of
https://gitlab.isc.org/isc-projects/bind9
synced 2025-08-31 14:35:26 +00:00
OS-independent filesystem permissions
This commit is contained in:
71
lib/isc/unix/fsaccess.c
Normal file
71
lib/isc/unix/fsaccess.c
Normal file
@@ -0,0 +1,71 @@
|
||||
#include <sys/types.h>
|
||||
#include <sys/stat.h>
|
||||
|
||||
#include <errno.h>
|
||||
|
||||
#include "errno2result.h"
|
||||
|
||||
/*
|
||||
* The OS-independent part of the API is in lib/isc.
|
||||
*/
|
||||
#include "../fsaccess.c"
|
||||
|
||||
isc_result_t
|
||||
isc_fsaccess_set(const char *path, isc_fsaccess_t access) {
|
||||
struct stat statb;
|
||||
mode_t mode;
|
||||
isc_boolean_t is_dir = ISC_FALSE;
|
||||
isc_fsaccess_t bits;
|
||||
isc_result_t result;
|
||||
|
||||
if (stat(path, &statb) != 0)
|
||||
return (isc__errno2result(errno));
|
||||
|
||||
if ((statb.st_mode & S_IFDIR) != 0)
|
||||
is_dir = ISC_TRUE;
|
||||
else if ((statb.st_mode & S_IFREG) == 0)
|
||||
return (ISC_R_INVALIDFILE);
|
||||
|
||||
result = check_bad_bits(access, is_dir);
|
||||
if (result != ISC_R_SUCCESS)
|
||||
return (result);
|
||||
|
||||
/*
|
||||
* Done with checking bad bits. Set mode_t.
|
||||
*/
|
||||
mode = 0;
|
||||
|
||||
#define SET_AND_CLEAR1(modebit) \
|
||||
if ((access & bits) != 0) { \
|
||||
mode |= modebit; \
|
||||
access &= ~bits; \
|
||||
}
|
||||
#define SET_AND_CLEAR(user, group, other) \
|
||||
SET_AND_CLEAR1(user); \
|
||||
bits <<= STEP; \
|
||||
SET_AND_CLEAR1(group); \
|
||||
bits <<= STEP; \
|
||||
SET_AND_CLEAR1(other);
|
||||
|
||||
bits = ISC_FSACCESS_READ | ISC_FSACCESS_LISTDIRECTORY;
|
||||
|
||||
SET_AND_CLEAR(S_IRUSR, S_IRGRP, S_IROTH);
|
||||
|
||||
bits = ISC_FSACCESS_WRITE |
|
||||
ISC_FSACCESS_CREATECHILD |
|
||||
ISC_FSACCESS_DELETECHILD;
|
||||
|
||||
SET_AND_CLEAR(S_IWUSR, S_IWGRP, S_IWOTH);
|
||||
|
||||
bits = ISC_FSACCESS_EXECUTE |
|
||||
ISC_FSACCESS_ACCESSCHILD;
|
||||
|
||||
SET_AND_CLEAR(S_IXUSR, S_IXGRP, S_IXOTH);
|
||||
|
||||
INSIST(access == 0);
|
||||
|
||||
if (chmod(path, mode) < 0)
|
||||
return (isc__errno2result(errno));
|
||||
|
||||
return (ISC_R_SUCCESS);
|
||||
}
|
Reference in New Issue
Block a user