From 5f43fb17acb5a37dc5b56b3493fa65eae25805b5 Mon Sep 17 00:00:00 2001 From: Giuseppe Scrivano Date: Mon, 22 Nov 2021 11:10:03 +0100 Subject: [PATCH] main: honor user.overlay. xattrs native overlay uses user.overlay to store the overlay metadata instead of trusted.overlay, let's honor it as well. Closes: https://github.com/containers/fuse-overlayfs/issues/328 Signed-off-by: Giuseppe Scrivano --- main.c | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/main.c b/main.c index 61872a1..92dbc84 100644 --- a/main.c +++ b/main.c @@ -137,6 +137,8 @@ open_by_handle_at (int mount_fd, struct file_handle *handle, int flags) #define ORIGIN_XATTR "user.fuseoverlayfs.origin" #define OPAQUE_XATTR "user.fuseoverlayfs.opaque" #define XATTR_CONTAINERS_PREFIX "user.containers." +#define UNPRIVILEGED_XATTR_PREFIX "user.overlay." +#define UNPRIVILEGED_OPAQUE_XATTR "user.overlay.opaque" #define PRIVILEGED_XATTR_PREFIX "trusted.overlay." #define PRIVILEGED_OPAQUE_XATTR "trusted.overlay.opaque" #define PRIVILEGED_ORIGIN_XATTR "trusted.overlay.origin" @@ -495,8 +497,9 @@ has_prefix (const char *str, const char *pref) static bool can_access_xattr (const char *name) { - return !has_prefix (name, XATTR_PREFIX) \ - && !has_prefix (name, PRIVILEGED_XATTR_PREFIX); + return !has_prefix (name, XATTR_PREFIX) + && !has_prefix (name, PRIVILEGED_XATTR_PREFIX) + && !has_prefix (name, UNPRIVILEGED_XATTR_PREFIX); } static ssize_t @@ -683,6 +686,8 @@ is_directory_opaque (struct ovl_layer *l, const char *path) ssize_t s; s = l->ds->getxattr (l, path, PRIVILEGED_OPAQUE_XATTR, b, sizeof (b)); + if (s < 0 && errno == ENODATA) + s = l->ds->getxattr (l, path, UNPRIVILEGED_OPAQUE_XATTR, b, sizeof (b)); if (s < 0 && errno == ENODATA) s = l->ds->getxattr (l, path, OPAQUE_XATTR, b, sizeof (b));