chroot connection plugin: defer get_option() call (#59065)
* The chroot connection plugin crashes because its constructor calls self.get_option(...) before the plugin loader has established its self._load_name. Therefore, we should defer the self.get_option(...) call so that it happens in connect(). Fixes #59063
This commit is contained in:
parent
88c4cf28ea
commit
b16c264dca
1 changed files with 2 additions and 2 deletions
|
@ -96,6 +96,8 @@ class Connection(ConnectionBase):
|
||||||
if not (is_executable(chrootsh) or (os.path.lexists(chrootsh) and os.path.islink(chrootsh))):
|
if not (is_executable(chrootsh) or (os.path.lexists(chrootsh) and os.path.islink(chrootsh))):
|
||||||
raise AnsibleError("%s does not look like a chrootable dir (/bin/sh missing)" % self.chroot)
|
raise AnsibleError("%s does not look like a chrootable dir (/bin/sh missing)" % self.chroot)
|
||||||
|
|
||||||
|
def _connect(self):
|
||||||
|
''' connect to the chroot '''
|
||||||
if os.path.isabs(self.get_option('chroot_exe')):
|
if os.path.isabs(self.get_option('chroot_exe')):
|
||||||
self.chroot_cmd = self.get_option('chroot_exe')
|
self.chroot_cmd = self.get_option('chroot_exe')
|
||||||
else:
|
else:
|
||||||
|
@ -104,8 +106,6 @@ class Connection(ConnectionBase):
|
||||||
if not self.chroot_cmd:
|
if not self.chroot_cmd:
|
||||||
raise AnsibleError("chroot command (%s) not found in PATH" % to_native(self.get_option('chroot_exe')))
|
raise AnsibleError("chroot command (%s) not found in PATH" % to_native(self.get_option('chroot_exe')))
|
||||||
|
|
||||||
def _connect(self):
|
|
||||||
''' connect to the chroot; nothing to do here '''
|
|
||||||
super(Connection, self)._connect()
|
super(Connection, self)._connect()
|
||||||
if not self._connected:
|
if not self._connected:
|
||||||
display.vvv("THIS IS A LOCAL CHROOT DIR", host=self.chroot)
|
display.vvv("THIS IS A LOCAL CHROOT DIR", host=self.chroot)
|
||||||
|
|
Loading…
Reference in a new issue