mirror of
https://github.com/systemd/systemd.git
synced 2025-01-09 01:18:19 +03:00
89 lines
3.3 KiB
Bash
Executable File
89 lines
3.3 KiB
Bash
Executable File
#!/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
|