]> git.ipfire.org Git - thirdparty/systemd.git/commitdiff
basic: add mknodat_label()
authorChristian Göttsche <cgzones@googlemail.com>
Sat, 27 Apr 2024 19:22:02 +0000 (21:22 +0200)
committerChristian Göttsche <cgzones@googlemail.com>
Mon, 29 Apr 2024 16:14:41 +0000 (18:14 +0200)
Add helper for mknodat(2) which creates the destination with the correct
security label.

src/shared/label-util.c
src/shared/label-util.h

index 308fbff761142808f3d8cb20df8d53f073c4f35f..2c482daaf6c4d786ae19b5c43dea2453c24e1328 100644 (file)
@@ -81,22 +81,23 @@ int symlink_atomic_full_label(const char *from, const char *to, bool make_relati
         return mac_smack_fix(to, 0);
 }
 
-int mknod_label(const char *pathname, mode_t mode, dev_t dev) {
+int mknodat_label(int dirfd, const char *pathname, mode_t mode, dev_t dev) {
         int r;
 
+        assert(dirfd >= 0 || dirfd == AT_FDCWD);
         assert(pathname);
 
-        r = mac_selinux_create_file_prepare(pathname, mode);
+        r = mac_selinux_create_file_prepare_at(dirfd, pathname, mode);
         if (r < 0)
                 return r;
 
-        r = RET_NERRNO(mknod(pathname, mode, dev));
+        r = RET_NERRNO(mknodat(dirfd, pathname, mode, dev));
         mac_selinux_create_file_clear();
 
         if (r < 0)
                 return r;
 
-        return mac_smack_fix(pathname, 0);
+        return mac_smack_fix_full(dirfd, pathname, NULL, 0);
 }
 
 int btrfs_subvol_make_label(const char *path) {
index 7fb98c76563e0b79d7e50b1bf655958d3e70edc5..5a19a4cd433047856d43a6268140b98f805461d6 100644 (file)
@@ -21,7 +21,11 @@ int symlink_atomic_full_label(const char *from, const char *to, bool make_relati
 static inline int symlink_atomic_label(const char *from, const char *to) {
         return symlink_atomic_full_label(from, to, false);
 }
-int mknod_label(const char *pathname, mode_t mode, dev_t dev);
+
+int mknodat_label(int dirfd, const char *pathname, mode_t mode, dev_t dev);
+static inline int mknod_label(const char *pathname, mode_t mode, dev_t dev) {
+        return mknodat_label(AT_FDCWD, pathname, mode, dev);
+}
 
 int btrfs_subvol_make_label(const char *path);