diff --git a/data/org.gnome.shell.gschema.xml.in.in b/data/org.gnome.shell.gschema.xml.in.in
index ccb28b2fe..e18685e9c 100644
--- a/data/org.gnome.shell.gschema.xml.in.in
+++ b/data/org.gnome.shell.gschema.xml.in.in
@@ -57,6 +57,14 @@ value here is from the TpConnectionPresenceType enumeration.
<_summary>Internally used to store the last session presence status for the user. The
value here is from the GsmPresenceStatus enumeration.
+
+ false
+ <_summary>Always show the 'Log out' menuitem in the user menu.
+ <_description>
+ This key overrides the automatic hiding of the 'Log out'
+ menuitem in single-user, single-session situations.
+
+
diff --git a/js/ui/userMenu.js b/js/ui/userMenu.js
index d68b4e657..d1bfdb856 100644
--- a/js/ui/userMenu.js
+++ b/js/ui/userMenu.js
@@ -26,6 +26,7 @@ const DISABLE_USER_SWITCH_KEY = 'disable-user-switching';
const DISABLE_LOCK_SCREEN_KEY = 'disable-lock-screen';
const DISABLE_LOG_OUT_KEY = 'disable-log-out';
const LOCK_ENABLED_KEY = 'lock-enabled';
+const ALWAYS_SHOW_LOG_OUT_KEY = 'always-show-log-out';
const DIALOG_ICON_SIZE = 64;
@@ -616,12 +617,13 @@ const UserMenuButton = new Lang.Class({
_updateLogout: function() {
let allowLogout = !this._lockdownSettings.get_boolean(DISABLE_LOG_OUT_KEY);
+ let alwaysShow = global.settings.get_boolean(ALWAYS_SHOW_LOG_OUT_KEY);
let systemAccount = this._user.system_account;
let localAccount = this._user.local_account;
let multiUser = this._userManager.has_multiple_users;
let multiSession = Gdm.get_session_ids().length > 1;
- this._logoutItem.actor.visible = allowLogout && (multiUser || multiSession || systemAccount || !localAccount);
+ this._logoutItem.actor.visible = allowLogout && (alwaysShow || multiUser || multiSession || systemAccount || !localAccount);
},
_updateLockScreen: function() {