1
1
mirror of https://github.com/systemd/systemd-stable.git synced 2025-01-03 01:17:45 +03:00

escape: Ensure that output is always valid UTF-8

This ensures that shell string escape operations will not produce output
with invalid UTF-8 from the input by escaping invalid UTF-8 data as if
they were single byte characters.

(cherry picked from commit 00f57157f3)
(cherry picked from commit e906fd2421)
(cherry picked from commit e0a674f7f8)
This commit is contained in:
msizanoen1 2023-03-01 17:35:17 +07:00 committed by Zbigniew Jędrzejewski-Szmek
parent 085795656a
commit dfa043ae1f

View File

@ -474,13 +474,19 @@ char* octescape(const char *s, size_t len) {
static char* strcpy_backslash_escaped(char *t, const char *s, const char *bad) { static char* strcpy_backslash_escaped(char *t, const char *s, const char *bad) {
assert(bad); assert(bad);
for (; *s; s++) while (*s) {
if (char_is_cc(*s)) int l = utf8_encoded_valid_unichar(s, SIZE_MAX);
t += cescape_char(*s, t);
else { if (char_is_cc(*s) || l < 0)
t += cescape_char(*(s++), t);
else if (l == 1) {
if (*s == '\\' || strchr(bad, *s)) if (*s == '\\' || strchr(bad, *s))
*(t++) = '\\'; *(t++) = '\\';
*(t++) = *s; *(t++) = *(s++);
} else {
t = mempcpy(t, s, l);
s += l;
}
} }
return t; return t;
@ -510,11 +516,16 @@ char* shell_maybe_quote(const char *s, ShellEscapeFlags flags) {
if (FLAGS_SET(flags, SHELL_ESCAPE_EMPTY) && isempty(s)) if (FLAGS_SET(flags, SHELL_ESCAPE_EMPTY) && isempty(s))
return strdup("\"\""); /* We don't use $'' here in the POSIX mode. "" is fine too. */ return strdup("\"\""); /* We don't use $'' here in the POSIX mode. "" is fine too. */
for (p = s; *p; p++) for (p = s; *p; ) {
if (char_is_cc(*p) || int l = utf8_encoded_valid_unichar(p, SIZE_MAX);
if (char_is_cc(*p) || l < 0 ||
strchr(WHITESPACE SHELL_NEED_QUOTES, *p)) strchr(WHITESPACE SHELL_NEED_QUOTES, *p))
break; break;
p += l;
}
if (!*p) if (!*p)
return strdup(s); return strdup(s);