1
0
Fork 0
mirror of https://github.com/ansible-collections/community.general.git synced 2024-09-14 20:13:21 +02:00

lxc_container - invoke run_command passing list (#3851)

* lxc_container - invoke run_command passing list

* added changelog fragment

* Update plugins/modules/cloud/lxc/lxc_container.py

Co-authored-by: Felix Fontein <felix@fontein.de>

Co-authored-by: Felix Fontein <felix@fontein.de>
This commit is contained in:
Alexei Znamensky 2021-12-10 10:02:43 +13:00 committed by GitHub
parent cbc9742747
commit 9a100e099e
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 29 additions and 44 deletions

View file

@ -0,0 +1,2 @@
minor_changes:
- lxc_container - calling ``run_command`` with arguments as ``list`` instead of ``str`` (https://github.com/ansible-collections/community.general/pull/3851).

View file

@ -422,6 +422,7 @@ import shutil
import subprocess import subprocess
import tempfile import tempfile
import time import time
import shlex
try: try:
import lxc import lxc
@ -661,9 +662,8 @@ class LxcContainerManagement(object):
""" """
for key, value in variables_dict.items(): for key, value in variables_dict.items():
build_command.append( build_command.append(str(key))
'%s %s' % (key, value) build_command.append(str(value))
)
return build_command return build_command
def _get_vars(self, variables): def _get_vars(self, variables):
@ -686,24 +686,6 @@ class LxcContainerManagement(object):
return_dict[v] = _var return_dict[v] = _var
return return_dict return return_dict
def _run_command(self, build_command, unsafe_shell=False):
"""Return information from running an Ansible Command.
This will squash the build command list into a string and then
execute the command via Ansible. The output is returned to the method.
This output is returned as `return_code`, `stdout`, `stderr`.
:param build_command: Used for the command and all options.
:type build_command: ``list``
:param unsafe_shell: Enable or Disable unsafe sell commands.
:type unsafe_shell: ``bol``
"""
return self.module.run_command(
' '.join(build_command),
use_unsafe_shell=unsafe_shell
)
def _config(self): def _config(self):
"""Configure an LXC container. """Configure an LXC container.
@ -810,7 +792,7 @@ class LxcContainerManagement(object):
elif self.module.params.get('backing_store') == 'overlayfs': elif self.module.params.get('backing_store') == 'overlayfs':
build_command.append('--snapshot') build_command.append('--snapshot')
rc, return_data, err = self._run_command(build_command) rc, return_data, err = self.module.run_command(build_command)
if rc != 0: if rc != 0:
message = "Failed executing %s." % os.path.basename(clone_cmd) message = "Failed executing %s." % os.path.basename(clone_cmd)
self.failure( self.failure(
@ -843,7 +825,7 @@ class LxcContainerManagement(object):
build_command = [ build_command = [
self.module.get_bin_path('lxc-create', True), self.module.get_bin_path('lxc-create', True),
'--name %s' % self.container_name, '--name', self.container_name,
'--quiet' '--quiet'
] ]
@ -869,10 +851,12 @@ class LxcContainerManagement(object):
log_path = os.getenv('HOME') log_path = os.getenv('HOME')
build_command.extend([ build_command.extend([
'--logfile %s' % os.path.join( '--logfile',
os.path.join(
log_path, 'lxc-%s.log' % self.container_name log_path, 'lxc-%s.log' % self.container_name
), ),
'--logpriority %s' % self.module.params.get( '--logpriority',
self.module.params.get(
'container_log_level' 'container_log_level'
).upper() ).upper()
]) ])
@ -880,9 +864,10 @@ class LxcContainerManagement(object):
# Add the template commands to the end of the command if there are any # Add the template commands to the end of the command if there are any
template_options = self.module.params.get('template_options', None) template_options = self.module.params.get('template_options', None)
if template_options: if template_options:
build_command.append('-- %s' % template_options) build_command.append('--')
build_command += shlex.split(template_options)
rc, return_data, err = self._run_command(build_command) rc, return_data, err = self.module.run_command(build_command)
if rc != 0: if rc != 0:
message = "Failed executing lxc-create." message = "Failed executing lxc-create."
self.failure( self.failure(
@ -1186,7 +1171,7 @@ class LxcContainerManagement(object):
self.module.get_bin_path('lxc-config', True), self.module.get_bin_path('lxc-config', True),
"lxc.bdev.lvm.vg" "lxc.bdev.lvm.vg"
] ]
rc, vg, err = self._run_command(build_command) rc, vg, err = self.module.run_command(build_command)
if rc != 0: if rc != 0:
self.failure( self.failure(
err=err, err=err,
@ -1204,7 +1189,7 @@ class LxcContainerManagement(object):
build_command = [ build_command = [
self.module.get_bin_path('lvs', True) self.module.get_bin_path('lvs', True)
] ]
rc, stdout, err = self._run_command(build_command) rc, stdout, err = self.module.run_command(build_command)
if rc != 0: if rc != 0:
self.failure( self.failure(
err=err, err=err,
@ -1231,7 +1216,7 @@ class LxcContainerManagement(object):
'--units', '--units',
'g' 'g'
] ]
rc, stdout, err = self._run_command(build_command) rc, stdout, err = self.module.run_command(build_command)
if rc != 0: if rc != 0:
self.failure( self.failure(
err=err, err=err,
@ -1262,7 +1247,7 @@ class LxcContainerManagement(object):
'--units', '--units',
'g' 'g'
] ]
rc, stdout, err = self._run_command(build_command) rc, stdout, err = self.module.run_command(build_command)
if rc != 0: if rc != 0:
self.failure( self.failure(
err=err, err=err,
@ -1311,7 +1296,7 @@ class LxcContainerManagement(object):
os.path.join(vg, source_lv), os.path.join(vg, source_lv),
"-L%sg" % snapshot_size_gb "-L%sg" % snapshot_size_gb
] ]
rc, stdout, err = self._run_command(build_command) rc, stdout, err = self.module.run_command(build_command)
if rc != 0: if rc != 0:
self.failure( self.failure(
err=err, err=err,
@ -1336,7 +1321,7 @@ class LxcContainerManagement(object):
"/dev/%s/%s" % (vg, lv_name), "/dev/%s/%s" % (vg, lv_name),
mount_point, mount_point,
] ]
rc, stdout, err = self._run_command(build_command) rc, stdout, err = self.module.run_command(build_command)
if rc != 0: if rc != 0:
self.failure( self.failure(
err=err, err=err,
@ -1380,9 +1365,8 @@ class LxcContainerManagement(object):
'.' '.'
] ]
rc, stdout, err = self._run_command( rc, stdout, err = self.module.run_command(
build_command=build_command, build_command
unsafe_shell=True
) )
os.umask(old_umask) os.umask(old_umask)
@ -1410,7 +1394,7 @@ class LxcContainerManagement(object):
"-f", "-f",
"%s/%s" % (vg, lv_name), "%s/%s" % (vg, lv_name),
] ]
rc, stdout, err = self._run_command(build_command) rc, stdout, err = self.module.run_command(build_command)
if rc != 0: if rc != 0:
self.failure( self.failure(
err=err, err=err,
@ -1442,11 +1426,10 @@ class LxcContainerManagement(object):
self.module.get_bin_path('rsync', True), self.module.get_bin_path('rsync', True),
'-aHAX', '-aHAX',
fs_path, fs_path,
temp_dir temp_dir,
] ]
rc, stdout, err = self._run_command( rc, stdout, err = self.module.run_command(
build_command, build_command,
unsafe_shell=True
) )
if rc != 0: if rc != 0:
self.failure( self.failure(
@ -1467,7 +1450,7 @@ class LxcContainerManagement(object):
self.module.get_bin_path('umount', True), self.module.get_bin_path('umount', True),
mount_point, mount_point,
] ]
rc, stdout, err = self._run_command(build_command) rc, stdout, err = self.module.run_command(build_command)
if rc != 0: if rc != 0:
self.failure( self.failure(
err=err, err=err,
@ -1489,12 +1472,12 @@ class LxcContainerManagement(object):
build_command = [ build_command = [
self.module.get_bin_path('mount', True), self.module.get_bin_path('mount', True),
'-t overlayfs', '-t', 'overlayfs',
'-o lowerdir=%s,upperdir=%s' % (lowerdir, upperdir), '-o', 'lowerdir=%s,upperdir=%s' % (lowerdir, upperdir),
'overlayfs', 'overlayfs',
mount_point, mount_point,
] ]
rc, stdout, err = self._run_command(build_command) rc, stdout, err = self.module.run_command(build_command)
if rc != 0: if rc != 0:
self.failure( self.failure(
err=err, err=err,