2023-02-22 10:44:15 +08:00
|
|
|
#!/usr/bin/python3
|
2023-08-27 00:16:30 +08:00
|
|
|
import subprocess
|
|
|
|
|
2023-08-26 18:24:13 +08:00
|
|
|
from api.utils.log import myLogger
|
2023-04-14 10:51:29 +08:00
|
|
|
from api.exception.command_exception import CommandException
|
2023-04-14 16:41:43 +08:00
|
|
|
from api.utils import const
|
2023-02-21 14:21:53 +08:00
|
|
|
|
2023-08-25 15:47:50 +08:00
|
|
|
|
|
|
|
# This fuction is for running shell commands on container
|
|
|
|
# cmd_str e.g: "ls -a"
|
|
|
|
# return string limit: 4000 chars? to do
|
2023-02-22 11:29:06 +08:00
|
|
|
def execute_command_output(cmd_str):
|
|
|
|
print(cmd_str)
|
2023-02-22 11:29:14 +08:00
|
|
|
out_str = subprocess.getoutput(cmd_str)
|
2023-02-22 11:29:06 +08:00
|
|
|
print(out_str)
|
|
|
|
return out_str
|
2023-02-22 14:43:36 +08:00
|
|
|
|
2023-08-25 15:47:50 +08:00
|
|
|
|
|
|
|
# This fuction is for running shell commands on host machine
|
|
|
|
# cmd_str e.g: "ls -a"
|
|
|
|
# return string limit: 4000 chars
|
2023-04-16 13:48:15 +08:00
|
|
|
def execute_command_output_all(cmd_str):
|
2023-02-22 14:43:36 +08:00
|
|
|
|
2023-03-15 17:55:05 +08:00
|
|
|
myLogger.info_logger("Start to execute cmd: " + cmd_str)
|
2023-04-14 10:51:29 +08:00
|
|
|
|
2023-07-27 10:09:15 +08:00
|
|
|
process = subprocess.run(f'nsenter -m -u -i -n -p -t 1 sh -c "{cmd_str}"', capture_output=True, bufsize=65536, check=False, text=True, shell=True)
|
2023-03-24 14:58:10 +08:00
|
|
|
|
2023-04-16 13:48:15 +08:00
|
|
|
if process.returncode == 0 and 'Fail' not in process.stdout and 'fail' not in process.stdout and 'Error' not in process.stdout and 'error' not in process.stdout:
|
2023-04-18 17:15:12 +08:00
|
|
|
|
2023-08-27 00:16:30 +08:00
|
|
|
return {"code": "0", "result": process.stdout}
|
2023-04-16 13:48:15 +08:00
|
|
|
else:
|
2023-04-19 16:07:30 +08:00
|
|
|
myLogger.info_logger("Failed to execute cmd, output failed result")
|
2023-04-18 16:55:28 +08:00
|
|
|
myLogger.info_logger(process)
|
2023-08-27 00:16:30 +08:00
|
|
|
raise CommandException(const.ERROR_SERVER_COMMAND, "Docker returns the original error", process.stderr)
|
2023-03-02 14:56:08 +08:00
|
|
|
|
2023-08-25 15:47:50 +08:00
|
|
|
|
|
|
|
|
|
|
|
# This fuction is convert container commands to host machine commands
|
2023-03-02 14:56:08 +08:00
|
|
|
def convert_command(cmd_str):
|
|
|
|
convert_cmd = ""
|
|
|
|
if cmd_str == "":
|
|
|
|
convert_cmd=cmd_str
|
|
|
|
else:
|
2023-03-24 14:02:24 +08:00
|
|
|
convert_cmd="nsenter -m -u -i -n -p -t 1 sh -c " + "'"+cmd_str+"'"
|
2023-03-02 14:56:08 +08:00
|
|
|
|
|
|
|
return convert_cmd
|