X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=src%2Fcore%2Fdbus-kill.c;h=fb29e147cbd0910b2f817b1528b5b3a833bd9305;hp=8d3e149f3314e348bcd55d88ffea9a891fc81b5e;hb=79008bddf679a5e0900369950eb346c9fa687107;hpb=556089dc57b10a12a03edd3d3e90ca17398ad206 diff --git a/src/core/dbus-kill.c b/src/core/dbus-kill.c index 8d3e149f3..fb29e147c 100644 --- a/src/core/dbus-kill.c +++ b/src/core/dbus-kill.c @@ -19,7 +19,6 @@ along with systemd; If not, see . ***/ -#include "bus-util.h" #include "kill.h" #include "dbus-kill.h" #include "bus-util.h" @@ -70,6 +69,24 @@ int bus_kill_context_set_transient_property( return 1; + } else if (streq(name, "KillSignal")) { + int sig; + + r = sd_bus_message_read(message, "i", &sig); + if (r < 0) + return r; + + if (sig <= 0 || sig >= _NSIG) + return sd_bus_error_setf(error, SD_BUS_ERROR_INVALID_ARGS, "Signal %i out of range", sig); + + if (mode != UNIT_CHECK) { + c->kill_signal = sig; + + unit_write_drop_in_private_format(u, mode, name, "KillSignal=%s\n", signal_to_string(sig)); + } + + return 1; + } else if (streq(name, "SendSIGHUP")) { int b;