ensure we have required systemd env var (#50607)

* ensure we have required systemd env var
* add clarification about systemd and user scope

  fixes #50272


(cherry picked from commit a7e81ba500)
pull/51090/head
Brian Coca 7 years ago committed by Toshio Kuratomi
parent 9c19df3fd2
commit 016bc83b58

@ -0,0 +1,2 @@
bugfixes:
- ensure we have a XDG_RUNTIME_DIR, as it is not handled correctly by some privilege escalation configurations

@ -59,6 +59,9 @@ options:
description: description:
- run systemctl within a given service manager scope, either as the default system scope (system), - run systemctl within a given service manager scope, either as the default system scope (system),
the current user's scope (user), or the scope of all users (global). the current user's scope (user), or the scope of all users (global).
- "For systemd to work with 'user', the executing user must have its own instance of dbus started (systemd requirement).
The user dbus process is normally started during normal login, but not during the run of Ansible tasks.
Otherwise you will probably get a 'Failed to connect to bus: no such file or directory' error."
choices: [ system, user, global ] choices: [ system, user, global ]
default: 'system' default: 'system'
version_added: "2.7" version_added: "2.7"
@ -245,6 +248,8 @@ status:
} }
''' # NOQA ''' # NOQA
import os
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.service import sysv_exists, sysv_is_enabled, fail_if_missing from ansible.module_utils.service import sysv_exists, sysv_is_enabled, fail_if_missing
from ansible.module_utils._text import to_native from ansible.module_utils._text import to_native
@ -317,6 +322,9 @@ def main():
systemctl = module.get_bin_path('systemctl', True) systemctl = module.get_bin_path('systemctl', True)
if os.getenv('XDG_RUNTIME_DIR') is None:
os.environ['XDG_RUNTIME_DIR'] = '/run/user/%s' % os.geteuid()
''' Set CLI options depending on params ''' ''' Set CLI options depending on params '''
if module.params['user'] is not None: if module.params['user'] is not None:
# handle user deprecation, mutually exclusive with scope # handle user deprecation, mutually exclusive with scope

Loading…
Cancel
Save