summaryrefslogtreecommitdiffstats
path: root/src/shared/bus-util.c
diff options
context:
space:
mode:
authorZbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl>2017-07-01 22:49:15 +0200
committerZbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl>2017-07-03 15:30:57 +0200
commit5993d46a1a4472cc5a9a227311f913ff934395a3 (patch)
tree8803bf6b3d06a1ff5dcb42826a00fa82233c66c2 /src/shared/bus-util.c
parentRevert "bus: when dumping string property values escape the chars we use as e... (diff)
downloadsystemd-5993d46a1a4472cc5a9a227311f913ff934395a3.tar.xz
systemd-5993d46a1a4472cc5a9a227311f913ff934395a3.zip
bus-util: replace non-printable values with [unprintable]
Like I said in the previous commit, such values do not seem to appear in normal use, but it's pretty hard to prove that all paths to assign values properly check that they contain no spaces. So just in case some slip through, replace values with spaces (in case of single-valued properties) or spaces and newlines (in case of array proprties) with "[unprintable]". We were already doing it in case of properties which we didn't know how to print, so this fits in well. The advantage is the previous code which used escaping that a) this is easier to spot, b) does not mess up printing of properties which were properly escaped already. v2: - add comments
Diffstat (limited to 'src/shared/bus-util.c')
-rw-r--r--src/shared/bus-util.c18
1 files changed, 15 insertions, 3 deletions
diff --git a/src/shared/bus-util.c b/src/shared/bus-util.c
index 8705a7b841..207b5e66fc 100644
--- a/src/shared/bus-util.c
+++ b/src/shared/bus-util.c
@@ -724,8 +724,14 @@ int bus_print_property(const char *name, sd_bus_message *property, bool value, b
if (r < 0)
return r;
- if (all || !isempty(s))
- print_property(name, "%s", s);
+ if (all || !isempty(s)) {
+ bool good;
+
+ /* This property has a single value, so we need to take
+ * care not to print a new line, everything else is OK. */
+ good = !strchr(s, '\n');
+ print_property(name, "%s", good ? s : "[unprintable]");
+ }
return 1;
}
@@ -845,10 +851,16 @@ int bus_print_property(const char *name, sd_bus_message *property, bool value, b
return r;
while ((r = sd_bus_message_read_basic(property, SD_BUS_TYPE_STRING, &str)) > 0) {
+ bool good;
+
if (first && !value)
printf("%s=", name);
- printf("%s%s", first ? "" : " ", str);
+ /* This property has multiple space-seperated values, so
+ * neither spaces not newlines can be allowed in a value. */
+ good = str[strcspn(str, " \n")] == '\0';
+
+ printf("%s%s", first ? "" : " ", good ? str : "[unprintable]");
first = false;
}