#!/usr/bin/env bash # SPDX-License-Identifier: LGPL-2.1-or-later set -eux set -o pipefail add_logs_filtering_override() { local unit="${1:?}" local override_name="${2:?}" local log_filter="${3:-}" mkdir -p "/run/systemd/system/$unit.d/" echo -ne "[Service]\nLogFilterPatterns=$log_filter" >"/run/systemd/system/$unit.d/$override_name.conf" systemctl daemon-reload } run_service_and_fetch_logs() { local unit="${1:?}" local start end start="$(date '+%Y-%m-%d %T.%6N')" systemctl restart "$unit" sleep .5 journalctl --sync end="$(date '+%Y-%m-%d %T.%6N')" journalctl -q -u "$unit" -S "$start" -U "$end" -p notice systemctl stop "$unit" } is_xattr_supported() { local start end start="$(date '+%Y-%m-%d %T.%6N')" systemd-run --unit text_xattr --property LogFilterPatterns=log sh -c "sleep .5" sleep .5 journalctl --sync end="$(date '+%Y-%m-%d %T.%6N')" systemctl stop text_xattr ! journalctl -q -u "text_xattr" -S "$start" -U "$end" --grep "Failed to set 'user.journald_log_filter_patterns' xattr.*not supported$" } if is_xattr_supported; then # Accept all log messages add_logs_filtering_override "logs-filtering.service" "00-reset" "" [[ -n $(run_service_and_fetch_logs "logs-filtering.service") ]] add_logs_filtering_override "logs-filtering.service" "01-allow-all" ".*" [[ -n $(run_service_and_fetch_logs "logs-filtering.service") ]] # Discard all log messages add_logs_filtering_override "logs-filtering.service" "02-discard-all" "~.*" [[ -z $(run_service_and_fetch_logs "logs-filtering.service") ]] # Accept all test messages add_logs_filtering_override "logs-filtering.service" "03-reset" "" [[ -n $(run_service_and_fetch_logs "logs-filtering.service") ]] # Discard all test messages add_logs_filtering_override "logs-filtering.service" "04-discard-gg" "~.*gg.*" [[ -z $(run_service_and_fetch_logs "logs-filtering.service") ]] # Deny filter takes precedence add_logs_filtering_override "logs-filtering.service" "05-allow-all-but-too-late" ".*" [[ -z $(run_service_and_fetch_logs "logs-filtering.service") ]] # Use tilde in a deny pattern add_logs_filtering_override "logs-filtering.service" "06-reset" "" add_logs_filtering_override "logs-filtering.service" "07-prevent-tilde" "~~more~" [[ -z $(run_service_and_fetch_logs "logs-filtering.service") ]] # Only allow a pattern that won't be matched add_logs_filtering_override "logs-filtering.service" "08-reset" "" add_logs_filtering_override "logs-filtering.service" "09-allow-only-non-existing" "non-existing string" [[ -z $(run_service_and_fetch_logs "logs-filtering.service") ]] # Allow a pattern starting with a tilde add_logs_filtering_override "logs-filtering.service" "10-allow-with-escape-char" "\\\\x7emore~" [[ -n $(run_service_and_fetch_logs "logs-filtering.service") ]] add_logs_filtering_override "delegated-cgroup-filtering.service" "00-allow-all" ".*" [[ -n $(run_service_and_fetch_logs "delegated-cgroup-filtering.service") ]] add_logs_filtering_override "delegated-cgroup-filtering.service" "01-discard-hello" "~hello" [[ -z $(run_service_and_fetch_logs "delegated-cgroup-filtering.service") ]] rm -rf /run/systemd/system/{logs-filtering,delegated-cgroup-filtering}.service.d fi