From 5261ba901845c084de5a8fd06500ed09bfb0bd80 Mon Sep 17 00:00:00 2001 From: Timofey Titovets Date: Fri, 15 Aug 2014 02:05:47 +0300 Subject: [PATCH] core: Refuse mount on symlink --- src/core/mount.c | 21 +++++++++++++++++++++ src/shared/util.c | 12 ++++++++++++ src/shared/util.h | 2 ++ 3 files changed, 35 insertions(+) diff --git a/src/core/mount.c b/src/core/mount.c index 39a9aaf2a..ec90b0a67 100644 --- a/src/core/mount.c +++ b/src/core/mount.c @@ -827,6 +827,23 @@ void warn_if_dir_nonempty(const char *unit, const char* where) { NULL); } +static int fail_if_symlink(const char *unit, const char* where) { + assert(where); + + if (is_symlink(where) > 0) { + log_struct_unit(LOG_WARNING, + unit, + "MESSAGE=%s: Mount on symlink %s not allowed.", + unit, where, + "WHERE=%s", where, + MESSAGE_ID(SD_MESSAGE_OVERMOUNTING), + NULL); + + return -ELOOP; + } + return 0; +} + static void mount_enter_unmounting(Mount *m) { int r; @@ -877,6 +894,10 @@ static void mount_enter_mounting(Mount *m) { if (p && mount_is_bind(p)) mkdir_p_label(p->what, m->directory_mode); + r = fail_if_symlink(m->meta.id, m->where); + if (r < 0) + goto fail; + if (m->from_fragment) r = exec_command_set( m->control_command, diff --git a/src/shared/util.c b/src/shared/util.c index 3d16cd1a1..0db4bd90e 100644 --- a/src/shared/util.c +++ b/src/shared/util.c @@ -6918,3 +6918,15 @@ int take_password_lock(const char *root) { return fd; } + +int is_symlink(const char *path) { + struct stat info; + + if (lstat(path, &info) < 0) + return -errno; + + if (S_ISLNK(info.st_mode)) + return 1; + + return 0; +} \ No newline at end of file diff --git a/src/shared/util.h b/src/shared/util.h index 101d2dfcf..bd8bbb268 100644 --- a/src/shared/util.h +++ b/src/shared/util.h @@ -966,3 +966,5 @@ char *tempfn_random(const char *p); bool is_localhost(const char *hostname); int take_password_lock(const char *root); + +int is_symlink(const char *path); \ No newline at end of file -- 2.30.2