From: Franck Bui Date: Fri, 27 Apr 2018 10:55:56 +0000 (+0200) Subject: basic/label: introduce mkdirat_label()/mkdirat_errno_wrapper() helpers X-Git-Tag: v240~864^2~12 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=1e9126316fa10f8f1e2d40b90c77fb63fe10f781;p=thirdparty%2Fsystemd.git basic/label: introduce mkdirat_label()/mkdirat_errno_wrapper() helpers --- diff --git a/src/basic/label.h b/src/basic/label.h index 08fd109bcf9..594fd65974c 100644 --- a/src/basic/label.h +++ b/src/basic/label.h @@ -12,6 +12,7 @@ typedef enum LabelFixFlags { int label_fix(const char *path, LabelFixFlags flags); int mkdir_label(const char *path, mode_t mode); +int mkdirat_label(int dirfd, const char *path, mode_t mode); int symlink_label(const char *old_path, const char *new_path); int btrfs_subvol_make_label(const char *path); diff --git a/src/basic/mkdir-label.c b/src/basic/mkdir-label.c index 1d51e92e9af..0eba7fc514b 100644 --- a/src/basic/mkdir-label.c +++ b/src/basic/mkdir-label.c @@ -28,6 +28,23 @@ int mkdir_label(const char *path, mode_t mode) { return mac_smack_fix(path, 0); } +int mkdirat_label(int dirfd, const char *path, mode_t mode) { + int r; + + assert(path); + + r = mac_selinux_create_file_prepare_at(dirfd, path, S_IFDIR); + if (r < 0) + return r; + + r = mkdirat_errno_wrapper(dirfd, path, mode); + mac_selinux_create_file_clear(); + if (r < 0) + return r; + + return mac_smack_fix_at(dirfd, path, 0); +} + int mkdir_safe_label(const char *path, mode_t mode, uid_t uid, gid_t gid, MkdirFlags flags) { return mkdir_safe_internal(path, mode, uid, gid, flags, mkdir_label); } diff --git a/src/basic/mkdir.c b/src/basic/mkdir.c index 6ab1b4422b4..4bb65d5838d 100644 --- a/src/basic/mkdir.c +++ b/src/basic/mkdir.c @@ -80,6 +80,12 @@ int mkdir_errno_wrapper(const char *pathname, mode_t mode) { return 0; } +int mkdirat_errno_wrapper(int dirfd, const char *pathname, mode_t mode) { + if (mkdirat(dirfd, pathname, mode) < 0) + return -errno; + return 0; +} + int mkdir_safe(const char *path, mode_t mode, uid_t uid, gid_t gid, MkdirFlags flags) { return mkdir_safe_internal(path, mode, uid, gid, flags, mkdir_errno_wrapper); } diff --git a/src/basic/mkdir.h b/src/basic/mkdir.h index bdca15460e8..eb54853ea78 100644 --- a/src/basic/mkdir.h +++ b/src/basic/mkdir.h @@ -9,6 +9,7 @@ typedef enum MkdirFlags { } MkdirFlags; int mkdir_errno_wrapper(const char *pathname, mode_t mode); +int mkdirat_errno_wrapper(int dirfd, const char *pathname, mode_t mode); int mkdir_safe(const char *path, mode_t mode, uid_t uid, gid_t gid, MkdirFlags flags); int mkdir_parents(const char *path, mode_t mode); int mkdir_p(const char *path, mode_t mode);