Compare commits

..

No commits in common. "8f335169e27b7c70f2f764170a09c2684a956c1c" and "6d3702f97ca0a9efb2d3290bb72559908699a3c9" have entirely different histories.

7 changed files with 33 additions and 108 deletions

View File

@ -92,7 +92,7 @@ A+ /path-or-glob/to/append/acls/recursively - - - - POSIX
directories during boot and to do periodic cleanup afterwards. See directories during boot and to do periodic cleanup afterwards. See
<citerefentry><refentrytitle>systemd-tmpfiles</refentrytitle><manvolnum>5</manvolnum></citerefentry> for <citerefentry><refentrytitle>systemd-tmpfiles</refentrytitle><manvolnum>5</manvolnum></citerefentry> for
the description of <filename>systemd-tmpfiles-setup.service</filename>, the description of <filename>systemd-tmpfiles-setup.service</filename>,
<filename>systemd-tmpfiles-clean.service</filename>, and associated units.</para> <filename>systemd-tmpfiles-cleanup.service</filename>, and associated units.</para>
<para>System daemons frequently require private runtime directories below <filename>/run</filename> to <para>System daemons frequently require private runtime directories below <filename>/run</filename> to
store communication sockets and similar. For these, it is better to use store communication sockets and similar. For these, it is better to use

View File

@ -312,25 +312,6 @@ int fchmod_opath(int fd, mode_t m) {
return 0; return 0;
} }
int futimens_opath(int fd, const struct timespec ts[2]) {
char procfs_path[STRLEN("/proc/self/fd/") + DECIMAL_STR_MAX(int)];
/* Similar to fchmod_path() but for futimens() */
xsprintf(procfs_path, "/proc/self/fd/%i", fd);
if (utimensat(AT_FDCWD, procfs_path, ts, 0) < 0) {
if (errno != ENOENT)
return -errno;
if (proc_mounted() == 0)
return -ENOSYS; /* if we have no /proc/, the concept is not implementable */
return -ENOENT;
}
return 0;
}
int stat_warn_permissions(const char *path, const struct stat *st) { int stat_warn_permissions(const char *path, const struct stat *st) {
assert(path); assert(path);
assert(st); assert(st);

View File

@ -38,8 +38,6 @@ int fchmod_and_chown(int fd, mode_t mode, uid_t uid, gid_t gid);
int fchmod_umask(int fd, mode_t mode); int fchmod_umask(int fd, mode_t mode);
int fchmod_opath(int fd, mode_t m); int fchmod_opath(int fd, mode_t m);
int futimens_opath(int fd, const struct timespec ts[2]);
int fd_warn_permissions(const char *path, int fd); int fd_warn_permissions(const char *path, int fd);
int stat_warn_permissions(const char *path, const struct stat *st); int stat_warn_permissions(const char *path, const struct stat *st);

View File

@ -205,11 +205,14 @@ static int mac_selinux_reload(int seqno) {
int mac_selinux_fix_container(const char *path, const char *inside_path, LabelFixFlags flags) { int mac_selinux_fix_container(const char *path, const char *inside_path, LabelFixFlags flags) {
assert(path);
assert(inside_path);
#if HAVE_SELINUX #if HAVE_SELINUX
char procfs_path[STRLEN("/proc/self/fd/") + DECIMAL_STR_MAX(int)];
_cleanup_freecon_ char* fcon = NULL;
_cleanup_close_ int fd = -1; _cleanup_close_ int fd = -1;
struct stat st;
int r;
assert(path);
/* if mac_selinux_init() wasn't called before we are a NOOP */ /* if mac_selinux_init() wasn't called before we are a NOOP */
if (!label_hnd) if (!label_hnd)
@ -224,27 +227,6 @@ int mac_selinux_fix_container(const char *path, const char *inside_path, LabelFi
return -errno; return -errno;
} }
return mac_selinux_fix_container_fd(fd, path, inside_path, flags);
#endif
return 0;
}
int mac_selinux_fix_container_fd(int fd, const char *path, const char *inside_path, LabelFixFlags flags) {
assert(fd >= 0);
assert(inside_path);
#if HAVE_SELINUX
char procfs_path[STRLEN("/proc/self/fd/") + DECIMAL_STR_MAX(int)];
_cleanup_freecon_ char* fcon = NULL;
struct stat st;
int r;
/* if mac_selinux_init() wasn't called before we are a NOOP */
if (!label_hnd)
return 0;
if (fstat(fd, &st) < 0) if (fstat(fd, &st) < 0)
return -errno; return -errno;
@ -252,11 +234,12 @@ int mac_selinux_fix_container_fd(int fd, const char *path, const char *inside_pa
mac_selinux_maybe_reload(); mac_selinux_maybe_reload();
if (selabel_lookup_raw(label_hnd, &fcon, inside_path, st.st_mode) < 0) { if (selabel_lookup_raw(label_hnd, &fcon, inside_path, st.st_mode) < 0) {
r = -errno;
/* If there's no label to set, then exit without warning */ /* If there's no label to set, then exit without warning */
if (errno == ENOENT) if (r == -ENOENT)
return 0; return 0;
r = -errno;
goto fail; goto fail;
} }
@ -264,16 +247,16 @@ int mac_selinux_fix_container_fd(int fd, const char *path, const char *inside_pa
if (setfilecon_raw(procfs_path, fcon) < 0) { if (setfilecon_raw(procfs_path, fcon) < 0) {
_cleanup_freecon_ char *oldcon = NULL; _cleanup_freecon_ char *oldcon = NULL;
r = -errno;
/* If the FS doesn't support labels, then exit without warning */ /* If the FS doesn't support labels, then exit without warning */
if (ERRNO_IS_NOT_SUPPORTED(errno)) if (r == -EOPNOTSUPP)
return 0; return 0;
/* It the FS is read-only and we were told to ignore failures caused by that, suppress error */ /* It the FS is read-only and we were told to ignore failures caused by that, suppress error */
if (errno == EROFS && (flags & LABEL_IGNORE_EROFS)) if (r == -EROFS && (flags & LABEL_IGNORE_EROFS))
return 0; return 0;
r = -errno;
/* If the old label is identical to the new one, suppress any kind of error */ /* If the old label is identical to the new one, suppress any kind of error */
if (getfilecon_raw(procfs_path, &oldcon) >= 0 && streq(fcon, oldcon)) if (getfilecon_raw(procfs_path, &oldcon) >= 0 && streq(fcon, oldcon))
return 0; return 0;
@ -284,7 +267,7 @@ int mac_selinux_fix_container_fd(int fd, const char *path, const char *inside_pa
return 0; return 0;
fail: fail:
return log_enforcing_errno(r, "Unable to fix SELinux security context of %s (%s): %m", strna(path), strna(inside_path)); return log_enforcing_errno(r, "Unable to fix SELinux security context of %s (%s): %m", path, inside_path);
#endif #endif
return 0; return 0;
@ -292,12 +275,11 @@ fail:
int mac_selinux_apply(const char *path, const char *label) { int mac_selinux_apply(const char *path, const char *label) {
assert(path);
#if HAVE_SELINUX #if HAVE_SELINUX
if (!mac_selinux_use()) if (!mac_selinux_use())
return 0; return 0;
assert(path);
assert(label); assert(label);
if (setfilecon(path, label) < 0) if (setfilecon(path, label) < 0)
@ -306,22 +288,6 @@ int mac_selinux_apply(const char *path, const char *label) {
return 0; return 0;
} }
int mac_selinux_apply_fd(int fd, const char *path, const char *label) {
assert(fd >= 0);
#if HAVE_SELINUX
if (!mac_selinux_use())
return 0;
assert(label);
if (fsetfilecon(fd, label) < 0)
return log_enforcing_errno(errno, "Failed to set SELinux security context %s on path %s: %m", label, strna(path));
#endif
return 0;
}
int mac_selinux_get_create_label_from_exe(const char *exe, char **label) { int mac_selinux_get_create_label_from_exe(const char *exe, char **label) {
#if HAVE_SELINUX #if HAVE_SELINUX
_cleanup_freecon_ char *mycon = NULL, *fcon = NULL; _cleanup_freecon_ char *mycon = NULL, *fcon = NULL;

View File

@ -28,13 +28,7 @@ static inline int mac_selinux_fix(const char *path, LabelFixFlags flags) {
return mac_selinux_fix_container(path, path, flags); return mac_selinux_fix_container(path, path, flags);
} }
int mac_selinux_fix_container_fd(int fd, const char *path, const char *inside_path, LabelFixFlags flags);
static inline int mac_selinux_fix_fd(int fd, const char *path, LabelFixFlags flags) {
return mac_selinux_fix_container_fd(fd, path, path, flags);
}
int mac_selinux_apply(const char *path, const char *label); int mac_selinux_apply(const char *path, const char *label);
int mac_selinux_apply_fd(int fd, const char *path, const char *label);
int mac_selinux_get_create_label_from_exe(const char *exe, char **label); int mac_selinux_get_create_label_from_exe(const char *exe, char **label);
int mac_selinux_get_our_label(char **label); int mac_selinux_get_our_label(char **label);

View File

@ -288,12 +288,10 @@ int device_is_renaming(sd_device *dev) {
assert(dev); assert(dev);
r = sd_device_get_property_value(dev, "ID_RENAMING", NULL); r = sd_device_get_property_value(dev, "ID_RENAMING", NULL);
if (r == -ENOENT) if (r < 0 && r != -ENOENT)
return false;
if (r < 0)
return r; return r;
return true; return r >= 0;
} }
bool device_for_action(sd_device *dev, DeviceAction action) { bool device_for_action(sd_device *dev, DeviceAction action) {

View File

@ -273,10 +273,9 @@ static int node_permissions_apply(sd_device *dev, bool apply_mac,
mode_t mode, uid_t uid, gid_t gid, mode_t mode, uid_t uid, gid_t gid,
OrderedHashmap *seclabel_list) { OrderedHashmap *seclabel_list) {
const char *devnode, *subsystem, *id_filename = NULL; const char *devnode, *subsystem, *id_filename = NULL;
bool apply_mode, apply_uid, apply_gid;
_cleanup_close_ int node_fd = -1;
struct stat stats; struct stat stats;
dev_t devnum; dev_t devnum;
bool apply_mode, apply_uid, apply_gid;
int r; int r;
assert(dev); assert(dev);
@ -297,26 +296,17 @@ static int node_permissions_apply(sd_device *dev, bool apply_mac,
else else
mode |= S_IFCHR; mode |= S_IFCHR;
node_fd = open(devnode, O_PATH|O_NOFOLLOW|O_CLOEXEC); if (lstat(devnode, &stats) < 0) {
if (node_fd < 0) { if (errno == ENOENT)
if (errno == ENOENT) { return 0; /* this is necessarily racey, so ignore missing the device */
log_device_debug_errno(dev, errno, "Device node %s is missing, skipping handling.", devnode);
return 0; /* This is necessarily racey, so ignore missing the device */
}
return log_device_debug_errno(dev, errno, "Cannot open node %s: %m", devnode);
}
if (fstat(node_fd, &stats) < 0)
return log_device_debug_errno(dev, errno, "cannot stat() node %s: %m", devnode); return log_device_debug_errno(dev, errno, "cannot stat() node %s: %m", devnode);
if ((mode != MODE_INVALID && (stats.st_mode & S_IFMT) != (mode & S_IFMT)) || stats.st_rdev != devnum) {
log_device_debug(dev, "Found node '%s' with non-matching devnum %s, skipping handling.",
devnode, id_filename);
return 0; /* We might process a device that already got replaced by the time we have a look
* at it, handle this gracefully and step away. */
} }
if ((mode != MODE_INVALID && (stats.st_mode & S_IFMT) != (mode & S_IFMT)) || stats.st_rdev != devnum)
return log_device_debug_errno(dev, SYNTHETIC_ERRNO(EEXIST),
"Found node '%s' with non-matching devnum %s, skip handling",
devnode, id_filename);
apply_mode = mode != MODE_INVALID && (stats.st_mode & 0777) != (mode & 0777); apply_mode = mode != MODE_INVALID && (stats.st_mode & 0777) != (mode & 0777);
apply_uid = uid_is_valid(uid) && stats.st_uid != uid; apply_uid = uid_is_valid(uid) && stats.st_uid != uid;
apply_gid = gid_is_valid(gid) && stats.st_gid != gid; apply_gid = gid_is_valid(gid) && stats.st_gid != gid;
@ -332,7 +322,7 @@ static int node_permissions_apply(sd_device *dev, bool apply_mac,
gid_is_valid(gid) ? gid : stats.st_gid, gid_is_valid(gid) ? gid : stats.st_gid,
mode != MODE_INVALID ? mode & 0777 : stats.st_mode & 0777); mode != MODE_INVALID ? mode & 0777 : stats.st_mode & 0777);
r = fchmod_and_chown(node_fd, mode, uid, gid); r = chmod_and_chown(devnode, mode, uid, gid);
if (r < 0) if (r < 0)
log_device_full_errno(dev, r == -ENOENT ? LOG_DEBUG : LOG_ERR, r, log_device_full_errno(dev, r == -ENOENT ? LOG_DEBUG : LOG_ERR, r,
"Failed to set owner/mode of %s to uid=" UID_FMT "Failed to set owner/mode of %s to uid=" UID_FMT
@ -355,7 +345,7 @@ static int node_permissions_apply(sd_device *dev, bool apply_mac,
if (streq(name, "selinux")) { if (streq(name, "selinux")) {
selinux = true; selinux = true;
q = mac_selinux_apply_fd(node_fd, devnode, label); q = mac_selinux_apply(devnode, label);
if (q < 0) if (q < 0)
log_device_full_errno(dev, q == -ENOENT ? LOG_DEBUG : LOG_ERR, q, log_device_full_errno(dev, q == -ENOENT ? LOG_DEBUG : LOG_ERR, q,
"SECLABEL: failed to set SELinux label '%s': %m", label); "SECLABEL: failed to set SELinux label '%s': %m", label);
@ -365,7 +355,7 @@ static int node_permissions_apply(sd_device *dev, bool apply_mac,
} else if (streq(name, "smack")) { } else if (streq(name, "smack")) {
smack = true; smack = true;
q = mac_smack_apply_fd(node_fd, SMACK_ATTR_ACCESS, label); q = mac_smack_apply(devnode, SMACK_ATTR_ACCESS, label);
if (q < 0) if (q < 0)
log_device_full_errno(dev, q == -ENOENT ? LOG_DEBUG : LOG_ERR, q, log_device_full_errno(dev, q == -ENOENT ? LOG_DEBUG : LOG_ERR, q,
"SECLABEL: failed to set SMACK label '%s': %m", label); "SECLABEL: failed to set SMACK label '%s': %m", label);
@ -378,15 +368,13 @@ static int node_permissions_apply(sd_device *dev, bool apply_mac,
/* set the defaults */ /* set the defaults */
if (!selinux) if (!selinux)
(void) mac_selinux_fix_fd(node_fd, devnode, LABEL_IGNORE_ENOENT); (void) mac_selinux_fix(devnode, LABEL_IGNORE_ENOENT);
if (!smack) if (!smack)
(void) mac_smack_apply_fd(node_fd, SMACK_ATTR_ACCESS, NULL); (void) mac_smack_apply(devnode, SMACK_ATTR_ACCESS, NULL);
} }
/* always update timestamp when we re-use the node, like on media change events */ /* always update timestamp when we re-use the node, like on media change events */
r = futimens_opath(node_fd, NULL); (void) utimensat(AT_FDCWD, devnode, NULL, 0);
if (r < 0)
log_device_debug_errno(dev, r, "Failed to adjust timestamp of node %s: %m", devnode);
return r; return r;
} }