mirror of
https://github.com/GNS3/gns3-server.git
synced 2025-01-18 23:43:48 +02:00
Use compatible shlex_quote to handle case where Windows needs double quotes around file names, not single quotes. Ref https://github.com/GNS3/gns3-gui/issues/2866
This commit is contained in:
parent
9d47050dff
commit
7cfd0d4d1d
@ -806,7 +806,7 @@ class Router(BaseNode):
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
await self._hypervisor.send('vm set_ghost_file "{name}" {ghost_file}'.format(name=self._name,
|
await self._hypervisor.send('vm set_ghost_file "{name}" {ghost_file}'.format(name=self._name,
|
||||||
ghost_file=shlex.quote(ghost_file)))
|
ghost_file=shlex.quote(ghost_file)))
|
||||||
|
|
||||||
log.info('Router "{name}" [{id}]: ghost file set to {ghost_file}'.format(name=self._name,
|
log.info('Router "{name}" [{id}]: ghost file set to {ghost_file}'.format(name=self._name,
|
||||||
id=self._id,
|
id=self._id,
|
||||||
|
@ -25,7 +25,6 @@ import os
|
|||||||
import re
|
import re
|
||||||
import math
|
import math
|
||||||
import shutil
|
import shutil
|
||||||
import shlex
|
|
||||||
import asyncio
|
import asyncio
|
||||||
import socket
|
import socket
|
||||||
import gns3server
|
import gns3server
|
||||||
@ -33,7 +32,7 @@ import subprocess
|
|||||||
import time
|
import time
|
||||||
import json
|
import json
|
||||||
|
|
||||||
from gns3server.utils import parse_version
|
from gns3server.utils import parse_version, shlex_quote
|
||||||
from gns3server.utils.asyncio import subprocess_check_output, cancellable_wait_run_in_executor
|
from gns3server.utils.asyncio import subprocess_check_output, cancellable_wait_run_in_executor
|
||||||
from .qemu_error import QemuError
|
from .qemu_error import QemuError
|
||||||
from .utils.qcow2 import Qcow2, Qcow2Error
|
from .utils.qcow2 import Qcow2, Qcow2Error
|
||||||
@ -969,7 +968,7 @@ class QemuVM(BaseNode):
|
|||||||
self.check_available_ram(self.ram)
|
self.check_available_ram(self.ram)
|
||||||
|
|
||||||
command = await self._build_command()
|
command = await self._build_command()
|
||||||
command_string = " ".join(shlex.quote(s) for s in command)
|
command_string = " ".join(shlex_quote(s) for s in command)
|
||||||
try:
|
try:
|
||||||
log.info("Starting QEMU with: {}".format(command_string))
|
log.info("Starting QEMU with: {}".format(command_string))
|
||||||
self._stdout_file = os.path.join(self.working_dir, "qemu.log")
|
self._stdout_file = os.path.join(self.working_dir, "qemu.log")
|
||||||
@ -1566,7 +1565,7 @@ class QemuVM(BaseNode):
|
|||||||
|
|
||||||
self._qemu_img_stdout_file = os.path.join(self.working_dir, "qemu-img.log")
|
self._qemu_img_stdout_file = os.path.join(self.working_dir, "qemu-img.log")
|
||||||
log.info("logging to {}".format(self._qemu_img_stdout_file))
|
log.info("logging to {}".format(self._qemu_img_stdout_file))
|
||||||
command_string = " ".join(shlex.quote(s) for s in command)
|
command_string = " ".join(shlex_quote(s) for s in command)
|
||||||
log.info("Executing qemu-img with: {}".format(command_string))
|
log.info("Executing qemu-img with: {}".format(command_string))
|
||||||
with open(self._qemu_img_stdout_file, "w", encoding="utf-8") as fd:
|
with open(self._qemu_img_stdout_file, "w", encoding="utf-8") as fd:
|
||||||
process = await asyncio.create_subprocess_exec(*command, stdout=fd, stderr=subprocess.STDOUT, cwd=self.working_dir)
|
process = await asyncio.create_subprocess_exec(*command, stdout=fd, stderr=subprocess.STDOUT, cwd=self.working_dir)
|
||||||
|
@ -27,12 +27,11 @@ import asyncio
|
|||||||
import subprocess
|
import subprocess
|
||||||
import logging
|
import logging
|
||||||
import codecs
|
import codecs
|
||||||
import shlex
|
|
||||||
|
|
||||||
from collections import OrderedDict
|
from collections import OrderedDict
|
||||||
from gns3server.utils.interfaces import interfaces
|
from gns3server.utils.interfaces import interfaces
|
||||||
from gns3server.utils.asyncio import subprocess_check_output
|
from gns3server.utils.asyncio import subprocess_check_output
|
||||||
from gns3server.utils import parse_version
|
from gns3server.utils import parse_version, shlex_quote
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
@ -387,7 +386,7 @@ class VMware(BaseManager):
|
|||||||
|
|
||||||
command = [vmrun_path, "-T", self.host_type, subcommand]
|
command = [vmrun_path, "-T", self.host_type, subcommand]
|
||||||
command.extend(args)
|
command.extend(args)
|
||||||
command_string = " ".join([shlex.quote(c) for c in command])
|
command_string = " ".join([shlex_quote(c) for c in command])
|
||||||
log.log(log_level, "Executing vmrun with command: {}".format(command_string))
|
log.log(log_level, "Executing vmrun with command: {}".format(command_string))
|
||||||
try:
|
try:
|
||||||
process = await asyncio.create_subprocess_exec(*command, stdout=asyncio.subprocess.PIPE, stderr=asyncio.subprocess.PIPE)
|
process = await asyncio.create_subprocess_exec(*command, stdout=asyncio.subprocess.PIPE, stderr=asyncio.subprocess.PIPE)
|
||||||
|
@ -16,7 +16,9 @@
|
|||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
|
||||||
|
import sys
|
||||||
import re
|
import re
|
||||||
|
import shlex
|
||||||
import textwrap
|
import textwrap
|
||||||
import posixpath
|
import posixpath
|
||||||
|
|
||||||
@ -87,3 +89,14 @@ def parse_version(version):
|
|||||||
version.append("000000")
|
version.append("000000")
|
||||||
version.append("final")
|
version.append("final")
|
||||||
return tuple(version)
|
return tuple(version)
|
||||||
|
|
||||||
|
|
||||||
|
def shlex_quote(s):
|
||||||
|
"""
|
||||||
|
Compatible shlex_quote to handle case where Windows needs double quotes around file names, not single quotes.
|
||||||
|
"""
|
||||||
|
|
||||||
|
if sys.platform.startswith("win"):
|
||||||
|
return s if re.match(r'^[-_\w./]+$', s) else '"%s"' % s.replace('"', '\\"')
|
||||||
|
else:
|
||||||
|
return shlex.quote(s)
|
||||||
|
Loading…
Reference in New Issue
Block a user