X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Flogin%2Flogind-dbus.c;h=235b1313d470d3f19f7739a2c1cf35b5aaaf572b;hb=f39d4a08e746e703d562076a0f622eb91dbdcd3e;hp=c9c58f3f823701f35af3311eb61a3c7205d890b7;hpb=f9cd6be10ece07e10488c05e270a0b5860779864;p=elogind.git diff --git a/src/login/logind-dbus.c b/src/login/logind-dbus.c index c9c58f3f8..235b1313d 100644 --- a/src/login/logind-dbus.c +++ b/src/login/logind-dbus.c @@ -1480,6 +1480,8 @@ static int method_do_shutdown_or_sleep( action_multiple_sessions, interactive, error, method, m); if (r < 0) return r; + if (r == 0) + return 1; /* No authorization for now, but the async polkit stuff will call us again when it has it */ } if (blocked) { @@ -1487,6 +1489,8 @@ static int method_do_shutdown_or_sleep( action_ignore_inhibit, interactive, error, method, m); if (r < 0) return r; + if (r == 0) + return 1; /* No authorization for now, but the async polkit stuff will call us again when it has it */ } if (!multiple_sessions && !blocked) { @@ -1494,6 +1498,8 @@ static int method_do_shutdown_or_sleep( action, interactive, error, method, m); if (r < 0) return r; + if (r == 0) + return 1; /* No authorization for now, but the async polkit stuff will call us again when it has it */ } r = bus_manager_shutdown_or_sleep_now_or_later(m, unit_name, w, error);