diff options
Diffstat (limited to 'src/shared')
| -rw-r--r-- | src/shared/machine-image.c | 12 | ||||
| -rw-r--r-- | src/shared/machine-image.h | 26 | 
2 files changed, 30 insertions, 8 deletions
| diff --git a/src/shared/machine-image.c b/src/shared/machine-image.c index d2f1c4a40c..bebfc40efe 100644 --- a/src/shared/machine-image.c +++ b/src/shared/machine-image.c @@ -401,8 +401,7 @@ int image_remove(Image *i) {          assert(i); -        if (path_equal(i->path, "/") || -            path_startswith(i->path, "/usr")) +        if (IMAGE_IS_VENDOR(i) || IMAGE_IS_HOST(i))                  return -EROFS;          settings = image_settings_path(i); @@ -474,8 +473,7 @@ int image_rename(Image *i, const char *new_name) {          if (!image_name_is_valid(new_name))                  return -EINVAL; -        if (path_equal(i->path, "/") || -            path_startswith(i->path, "/usr")) +        if (IMAGE_IS_VENDOR(i) || IMAGE_IS_HOST(i))                  return -EROFS;          settings = image_settings_path(i); @@ -642,8 +640,7 @@ int image_read_only(Image *i, bool b) {          int r;          assert(i); -        if (path_equal(i->path, "/") || -            path_startswith(i->path, "/usr")) +        if (IMAGE_IS_VENDOR(i) || IMAGE_IS_HOST(i))                  return -EROFS;          /* Make sure we don't interfere with a running nspawn */ @@ -751,8 +748,7 @@ int image_path_lock(const char *path, int operation, LockFile *global, LockFile  int image_set_limit(Image *i, uint64_t referenced_max) {          assert(i); -        if (path_equal(i->path, "/") || -            path_startswith(i->path, "/usr")) +        if (IMAGE_IS_VENDOR(i) || IMAGE_IS_HOST(i))                  return -EROFS;          if (i->type != IMAGE_SUBVOLUME) diff --git a/src/shared/machine-image.h b/src/shared/machine-image.h index 31b720d50c..7410168c4f 100644 --- a/src/shared/machine-image.h +++ b/src/shared/machine-image.h @@ -25,6 +25,8 @@  #include "hashmap.h"  #include "lockfile-util.h"  #include "macro.h" +#include "path-util.h" +#include "string-util.h"  #include "time-util.h"  typedef enum ImageType { @@ -75,3 +77,27 @@ int image_path_lock(const char *path, int operation, LockFile *global, LockFile  int image_name_lock(const char *name, int operation, LockFile *ret);  int image_set_limit(Image *i, uint64_t referenced_max); + +static inline bool IMAGE_IS_HIDDEN(const struct Image *i) { +        assert(i); + +        return i->name && i->name[0] == '.'; +} + +static inline bool IMAGE_IS_VENDOR(const struct Image *i) { +        assert(i); + +        return i->path && path_startswith(i->path, "/usr"); +} + +static inline bool IMAGE_IS_HOST(const struct Image *i) { +        assert(i); + +        if (i->name && streq(i->name, ".host")) +                return true; + +        if (i->path && path_equal(i->path, "/")) +                return true; + +        return false; +} | 
