summaryrefslogtreecommitdiffstats
path: root/src/shared/acl-util.c
diff options
context:
space:
mode:
authorLennart Poettering <lennart@poettering.net>2020-07-21 22:19:17 +0200
committerLennart Poettering <lennart@poettering.net>2020-07-21 22:58:40 +0200
commit2ea6247e0188c3fb9194c5319e707f6a591d62fd (patch)
tree802c80e20166f68120f3a7bb4c3be80e30809a75 /src/shared/acl-util.c
parentoffline-passwd: use chase_symlinks() (diff)
downloadsystemd-2ea6247e0188c3fb9194c5319e707f6a591d62fd.tar.xz
systemd-2ea6247e0188c3fb9194c5319e707f6a591d62fd.zip
acl-util: fix error handling in add_acls_for_user()
Diffstat (limited to '')
-rw-r--r--src/shared/acl-util.c14
1 files changed, 10 insertions, 4 deletions
diff --git a/src/shared/acl-util.c b/src/shared/acl-util.c
index 1ccb4f8295..dd2b1efb11 100644
--- a/src/shared/acl-util.c
+++ b/src/shared/acl-util.c
@@ -378,10 +378,13 @@ int acls_for_file(const char *path, acl_type_t type, acl_t new, acl_t *acl) {
int add_acls_for_user(int fd, uid_t uid) {
_cleanup_(acl_freep) acl_t acl = NULL;
- acl_entry_t entry;
acl_permset_t permset;
+ acl_entry_t entry;
int r;
+ assert(fd >= 0);
+ assert(uid_is_valid(uid));
+
acl = acl_get_fd(fd);
if (!acl)
return -errno;
@@ -394,8 +397,8 @@ int add_acls_for_user(int fd, uid_t uid) {
return -errno;
}
- /* We do not recalculate the mask unconditionally here,
- * so that the fchmod() mask above stays intact. */
+ /* We do not recalculate the mask unconditionally here, so that the fchmod() mask above stays
+ * intact. */
if (acl_get_permset(entry, &permset) < 0 ||
acl_add_perm(permset, ACL_READ) < 0)
return -errno;
@@ -404,5 +407,8 @@ int add_acls_for_user(int fd, uid_t uid) {
if (r < 0)
return r;
- return acl_set_fd(fd, acl);
+ if (acl_set_fd(fd, acl) < 0)
+ return -errno;
+
+ return 0;
}