dcavalca / rpms / systemd

Forked from rpms/systemd 2 years ago
Clone
Zbigniew Jędrzejewski-Szmek 7f93bc
From 01ed2927822932a028701fc2ed7fb4440177cf45 Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek a59965
From: Lennart Poettering <lennart@poettering.net>
Zbigniew Jędrzejewski-Szmek a59965
Date: Tue, 17 Jun 2014 00:53:49 +0200
Zbigniew Jędrzejewski-Szmek a59965
Subject: [PATCH] install: make sure that --root= mode doesn't make us consider
Zbigniew Jędrzejewski-Szmek a59965
 all units outside of search path
Zbigniew Jędrzejewski-Szmek a59965
Zbigniew Jędrzejewski-Szmek a59965
(cherry picked from commit 8f294b45cbb627d31342f6a79444be59ce7e2274)
Zbigniew Jędrzejewski-Szmek a59965
(cherry picked from commit 9139b554df671481a7e03e928d661420bffb8774)
Zbigniew Jędrzejewski-Szmek a59965
---
Zbigniew Jędrzejewski-Szmek a59965
 src/shared/install.c | 41 +++++++++++++++++++++++++++++++++++++----
Zbigniew Jędrzejewski-Szmek a59965
 src/shared/util.c    | 16 ----------------
Zbigniew Jędrzejewski-Szmek a59965
 src/shared/util.h    |  1 -
Zbigniew Jędrzejewski-Szmek a59965
 3 files changed, 37 insertions(+), 21 deletions(-)
Zbigniew Jędrzejewski-Szmek a59965
Zbigniew Jędrzejewski-Szmek a59965
diff --git a/src/shared/install.c b/src/shared/install.c
Zbigniew Jędrzejewski-Szmek a59965
index e772c45..5d93a2e 100644
Zbigniew Jędrzejewski-Szmek a59965
--- a/src/shared/install.c
Zbigniew Jędrzejewski-Szmek a59965
+++ b/src/shared/install.c
Zbigniew Jędrzejewski-Szmek a59965
@@ -47,6 +47,37 @@ typedef struct {
Zbigniew Jędrzejewski-Szmek a59965
 #define _cleanup_lookup_paths_free_ _cleanup_(lookup_paths_free)
Zbigniew Jędrzejewski-Szmek a59965
 #define _cleanup_install_context_done_ _cleanup_(install_context_done)
Zbigniew Jędrzejewski-Szmek a59965
 
Zbigniew Jędrzejewski-Szmek a59965
+static int in_search_path(const char *path, char **search, const char *root_dir) {
Zbigniew Jędrzejewski-Szmek a59965
+        _cleanup_free_ char *parent = NULL;
Zbigniew Jędrzejewski-Szmek a59965
+        char **i;
Zbigniew Jędrzejewski-Szmek a59965
+        int r;
Zbigniew Jędrzejewski-Szmek a59965
+
Zbigniew Jędrzejewski-Szmek a59965
+        assert(path);
Zbigniew Jędrzejewski-Szmek a59965
+
Zbigniew Jędrzejewski-Szmek a59965
+        r = path_get_parent(path, &parent);
Zbigniew Jędrzejewski-Szmek a59965
+        if (r < 0)
Zbigniew Jędrzejewski-Szmek a59965
+                return r;
Zbigniew Jędrzejewski-Szmek a59965
+
Zbigniew Jędrzejewski-Szmek a59965
+        STRV_FOREACH(i, search) {
Zbigniew Jędrzejewski-Szmek a59965
+                _cleanup_free_ char *buf = NULL;
Zbigniew Jędrzejewski-Szmek a59965
+                const char *p;
Zbigniew Jędrzejewski-Szmek a59965
+
Zbigniew Jędrzejewski-Szmek a59965
+                if (root_dir) {
Zbigniew Jędrzejewski-Szmek a59965
+                        buf = strjoin(root_dir, "/", *i, NULL);
Zbigniew Jędrzejewski-Szmek a59965
+                        if (!buf)
Zbigniew Jędrzejewski-Szmek a59965
+                                return -ENOMEM;
Zbigniew Jędrzejewski-Szmek a59965
+
Zbigniew Jędrzejewski-Szmek a59965
+                        p = buf;
Zbigniew Jędrzejewski-Szmek a59965
+                } else
Zbigniew Jędrzejewski-Szmek a59965
+                        p = *i;
Zbigniew Jędrzejewski-Szmek a59965
+
Zbigniew Jędrzejewski-Szmek a59965
+                if (path_equal(parent, p))
Zbigniew Jędrzejewski-Szmek a59965
+                        return 1;
Zbigniew Jędrzejewski-Szmek a59965
+        }
Zbigniew Jędrzejewski-Szmek a59965
+
Zbigniew Jędrzejewski-Szmek a59965
+        return 0;
Zbigniew Jędrzejewski-Szmek a59965
+}
Zbigniew Jędrzejewski-Szmek a59965
+
Zbigniew Jędrzejewski-Szmek a59965
 static int lookup_paths_init_from_scope(LookupPaths *paths,
Zbigniew Jędrzejewski-Szmek a59965
                                         UnitFileScope scope,
Zbigniew Jędrzejewski-Szmek a59965
                                         const char *root_dir) {
Zbigniew Jędrzejewski-Szmek a59965
@@ -759,7 +790,7 @@ int unit_file_link(
Zbigniew Jędrzejewski-Szmek a59965
                         continue;
Zbigniew Jędrzejewski-Szmek a59965
                 }
Zbigniew Jędrzejewski-Szmek a59965
 
Zbigniew Jędrzejewski-Szmek a59965
-                q = in_search_path(*i, paths.unit_path);
Zbigniew Jędrzejewski-Szmek a59965
+                q = in_search_path(*i, paths.unit_path, root_dir);
Zbigniew Jędrzejewski-Szmek a59965
                 if (q < 0)
Zbigniew Jędrzejewski-Szmek a59965
                         return q;
Zbigniew Jędrzejewski-Szmek a59965
 
Zbigniew Jędrzejewski-Szmek a59965
@@ -1315,6 +1346,7 @@ static int install_info_symlink_link(
Zbigniew Jędrzejewski-Szmek a59965
                 InstallInfo *i,
Zbigniew Jędrzejewski-Szmek a59965
                 LookupPaths *paths,
Zbigniew Jędrzejewski-Szmek a59965
                 const char *config_path,
Zbigniew Jędrzejewski-Szmek a59965
+                const char *root_dir,
Zbigniew Jędrzejewski-Szmek a59965
                 bool force,
Zbigniew Jędrzejewski-Szmek a59965
                 UnitFileChange **changes,
Zbigniew Jędrzejewski-Szmek a59965
                 unsigned *n_changes) {
Zbigniew Jędrzejewski-Szmek a59965
@@ -1327,7 +1359,7 @@ static int install_info_symlink_link(
Zbigniew Jędrzejewski-Szmek a59965
         assert(config_path);
Zbigniew Jędrzejewski-Szmek a59965
         assert(i->path);
Zbigniew Jędrzejewski-Szmek a59965
 
Zbigniew Jędrzejewski-Szmek a59965
-        r = in_search_path(i->path, paths->unit_path);
Zbigniew Jędrzejewski-Szmek a59965
+        r = in_search_path(i->path, paths->unit_path, root_dir);
Zbigniew Jędrzejewski-Szmek a59965
         if (r != 0)
Zbigniew Jędrzejewski-Szmek a59965
                 return r;
Zbigniew Jędrzejewski-Szmek a59965
 
Zbigniew Jędrzejewski-Szmek a59965
@@ -1342,6 +1374,7 @@ static int install_info_apply(
Zbigniew Jędrzejewski-Szmek a59965
                 InstallInfo *i,
Zbigniew Jędrzejewski-Szmek a59965
                 LookupPaths *paths,
Zbigniew Jędrzejewski-Szmek a59965
                 const char *config_path,
Zbigniew Jędrzejewski-Szmek a59965
+                const char *root_dir,
Zbigniew Jędrzejewski-Szmek a59965
                 bool force,
Zbigniew Jędrzejewski-Szmek a59965
                 UnitFileChange **changes,
Zbigniew Jędrzejewski-Szmek a59965
                 unsigned *n_changes) {
Zbigniew Jędrzejewski-Szmek a59965
@@ -1362,7 +1395,7 @@ static int install_info_apply(
Zbigniew Jędrzejewski-Szmek a59965
         if (r == 0)
Zbigniew Jędrzejewski-Szmek a59965
                 r = q;
Zbigniew Jędrzejewski-Szmek a59965
 
Zbigniew Jędrzejewski-Szmek a59965
-        q = install_info_symlink_link(i, paths, config_path, force, changes, n_changes);
Zbigniew Jędrzejewski-Szmek a59965
+        q = install_info_symlink_link(i, paths, config_path, root_dir, force, changes, n_changes);
Zbigniew Jędrzejewski-Szmek a59965
         if (r == 0)
Zbigniew Jędrzejewski-Szmek a59965
                 r = q;
Zbigniew Jędrzejewski-Szmek a59965
 
Zbigniew Jędrzejewski-Szmek a59965
@@ -1402,7 +1435,7 @@ static int install_context_apply(
Zbigniew Jędrzejewski-Szmek a59965
                 } else if (r >= 0)
Zbigniew Jędrzejewski-Szmek a59965
                         r += q;
Zbigniew Jędrzejewski-Szmek a59965
 
Zbigniew Jędrzejewski-Szmek a59965
-                q = install_info_apply(i, paths, config_path, force, changes, n_changes);
Zbigniew Jędrzejewski-Szmek a59965
+                q = install_info_apply(i, paths, config_path, root_dir, force, changes, n_changes);
Zbigniew Jędrzejewski-Szmek a59965
                 if (r >= 0 && q < 0)
Zbigniew Jędrzejewski-Szmek a59965
                         r = q;
Zbigniew Jędrzejewski-Szmek a59965
         }
Zbigniew Jędrzejewski-Szmek a59965
diff --git a/src/shared/util.c b/src/shared/util.c
Zbigniew Jędrzejewski-Szmek 7f93bc
index 1f83eb7..f034134 100644
Zbigniew Jędrzejewski-Szmek a59965
--- a/src/shared/util.c
Zbigniew Jędrzejewski-Szmek a59965
+++ b/src/shared/util.c
Zbigniew Jędrzejewski-Szmek a59965
@@ -4520,22 +4520,6 @@ int dirent_ensure_type(DIR *d, struct dirent *de) {
Zbigniew Jędrzejewski-Szmek a59965
         return 0;
Zbigniew Jędrzejewski-Szmek a59965
 }
Zbigniew Jędrzejewski-Szmek a59965
 
Zbigniew Jędrzejewski-Szmek a59965
-int in_search_path(const char *path, char **search) {
Zbigniew Jędrzejewski-Szmek a59965
-        char **i;
Zbigniew Jędrzejewski-Szmek a59965
-        _cleanup_free_ char *parent = NULL;
Zbigniew Jędrzejewski-Szmek a59965
-        int r;
Zbigniew Jędrzejewski-Szmek a59965
-
Zbigniew Jędrzejewski-Szmek a59965
-        r = path_get_parent(path, &parent);
Zbigniew Jędrzejewski-Szmek a59965
-        if (r < 0)
Zbigniew Jędrzejewski-Szmek a59965
-                return r;
Zbigniew Jędrzejewski-Szmek a59965
-
Zbigniew Jędrzejewski-Szmek a59965
-        STRV_FOREACH(i, search)
Zbigniew Jędrzejewski-Szmek a59965
-                if (path_equal(parent, *i))
Zbigniew Jędrzejewski-Szmek a59965
-                        return 1;
Zbigniew Jędrzejewski-Szmek a59965
-
Zbigniew Jędrzejewski-Szmek a59965
-        return 0;
Zbigniew Jędrzejewski-Szmek a59965
-}
Zbigniew Jędrzejewski-Szmek a59965
-
Zbigniew Jędrzejewski-Szmek a59965
 int get_files_in_directory(const char *path, char ***list) {
Zbigniew Jędrzejewski-Szmek a59965
         _cleanup_closedir_ DIR *d = NULL;
Zbigniew Jędrzejewski-Szmek a59965
         size_t bufsize = 0, n = 0;
Zbigniew Jędrzejewski-Szmek a59965
diff --git a/src/shared/util.h b/src/shared/util.h
Zbigniew Jędrzejewski-Szmek a59965
index 3f97663..f358362 100644
Zbigniew Jędrzejewski-Szmek a59965
--- a/src/shared/util.h
Zbigniew Jędrzejewski-Szmek a59965
+++ b/src/shared/util.h
Zbigniew Jędrzejewski-Szmek a59965
@@ -477,7 +477,6 @@ int glob_extend(char ***strv, const char *path);
Zbigniew Jędrzejewski-Szmek a59965
 
Zbigniew Jędrzejewski-Szmek a59965
 int dirent_ensure_type(DIR *d, struct dirent *de);
Zbigniew Jędrzejewski-Szmek a59965
 
Zbigniew Jędrzejewski-Szmek a59965
-int in_search_path(const char *path, char **search);
Zbigniew Jędrzejewski-Szmek a59965
 int get_files_in_directory(const char *path, char ***list);
Zbigniew Jędrzejewski-Szmek a59965
 
Zbigniew Jędrzejewski-Szmek a59965
 char *strjoin(const char *x, ...) _sentinel_;