mirror of
https://github.com/Websoft9/websoft9.git
synced 2025-01-24 10:17:15 +08:00
update
This commit is contained in:
parent
f7b3265b97
commit
99a5902c5a
@ -35,13 +35,13 @@ def get_my_app(app_name=None):
|
|||||||
def set_app_info(output_list, num):
|
def set_app_info(output_list, num):
|
||||||
ip_result = shell_execute.execute_command_output_all("curl ifconfig.me")
|
ip_result = shell_execute.execute_command_output_all("curl ifconfig.me")
|
||||||
ip = ip_result["result"]
|
ip = ip_result["result"]
|
||||||
list = []
|
app_list = []
|
||||||
for i in range(0, num):
|
for i in range(0, num):
|
||||||
name = output_list[3 * i] # name
|
app_name = output_list[3 * i] # app_name
|
||||||
image_url = "https://libs.websoft9.com/Websoft9/logo/product/" + name + "-websoft9.png"
|
image_url = "https://libs.websoft9.com/Websoft9/logo/product/" + app_name + "-websoft9.png"
|
||||||
# get trade_mark
|
# get trade_mark
|
||||||
trade_mark = ""
|
trade_mark = ""
|
||||||
var_path = "/data/apps/" + name + "/variables.json"
|
var_path = "/data/apps/" + app_name + "/variables.json"
|
||||||
try:
|
try:
|
||||||
f = open(var_path, 'r', encoding='utf-8')
|
f = open(var_path, 'r', encoding='utf-8')
|
||||||
var = json.load(f)
|
var = json.load(f)
|
||||||
@ -68,34 +68,48 @@ def set_app_info(output_list, num):
|
|||||||
volume = output_list[3 * i + j]
|
volume = output_list[3 * i + j]
|
||||||
j = j + 1
|
j = j + 1
|
||||||
# get env info
|
# get env info
|
||||||
path = "/data/apps/" + name + "/.env"
|
path = "/data/apps/" + app_name + "/.env"
|
||||||
http_port = docker.read_env(path, "APP_HTTP_PORT")
|
|
||||||
db_port = docker.read_env(path, "APP_DB.*_PORT")
|
|
||||||
# get port and url
|
|
||||||
port = 0
|
port = 0
|
||||||
url = "-"
|
url = "-"
|
||||||
admin_url = "-"
|
admin_url = "-"
|
||||||
if http_port != "":
|
# get port and url
|
||||||
|
try:
|
||||||
|
http_port = list(docker.read_env(path, "APP_HTTP_PORT").values())[0]
|
||||||
port = int(http_port)
|
port = int(http_port)
|
||||||
easy_url = "http://" + ip + ":" + str(port)
|
easy_url = "http://" + ip + ":" + str(port)
|
||||||
url = get_url(app_name, easy_url)
|
url = get_url(app_name, easy_url)
|
||||||
admin_url = get_admin_url(app_name, url)
|
admin_url = get_admin_url(app_name, url)
|
||||||
elif db_port != "":
|
except IndexError:
|
||||||
port = int(db_port)
|
try:
|
||||||
|
db_port = list(docker.read_env(path, "APP_DB.*_PORT").values())[0]
|
||||||
|
port = int(db_port)
|
||||||
|
except IndexError:
|
||||||
|
pass
|
||||||
# get user_name
|
# get user_name
|
||||||
user_name = docker.read_env(path, "APP_USER")
|
user_name = "-"
|
||||||
if user_name == "":
|
try:
|
||||||
user_name = "-"
|
user_name = list(docker.read_env(path, "APP_USER").values())[0]
|
||||||
|
except IndexError:
|
||||||
|
pass
|
||||||
# get password
|
# get password
|
||||||
password = docker.read_env(path, "POWER_PASSWORD")
|
password = "-"
|
||||||
if password == "":
|
try:
|
||||||
password = "-"
|
password = list(docker.read_env(path, "POWER_PASSWORD").values())[0]
|
||||||
|
except IndexError:
|
||||||
|
pass
|
||||||
|
|
||||||
app = App(id=id, name=name, status_code=case_code, status=case, port=port, volume=volume, url=url,
|
app = App(id=id, name=app_name, status_code=case_code, status=case, port=port, volume=volume, url=url,
|
||||||
image_url=image_url, admin_url=admin_url, trade_mark=trade_mark, user_name=user_name, password=password)
|
image_url=image_url, admin_url=admin_url, trade_mark=trade_mark, user_name=user_name, password=password)
|
||||||
list.append(app.dict())
|
app_list.append(app.dict())
|
||||||
return list
|
|
||||||
|
file_path = "/data/apps/running_apps.txt"
|
||||||
|
if os.path.exists(file_path) and os.path.getsize(file_path):
|
||||||
|
with open(file_path, "r", encoding="utf-8") as f:
|
||||||
|
for running_app_name in f:
|
||||||
|
app = App(id=0, name=running_app_name, status_code=const.RETURN_READY, status="ready", port=0, volume="-",
|
||||||
|
url="-",image_url="-", admin_url="-", trade_mark="-", user_name="-",password="-")
|
||||||
|
app_list.append(app.dict())
|
||||||
|
return app_list
|
||||||
|
|
||||||
def get_url(app_name,easy_url):
|
def get_url(app_name,easy_url):
|
||||||
|
|
||||||
@ -131,15 +145,18 @@ def install_app_process(app_name):
|
|||||||
return ret
|
return ret
|
||||||
|
|
||||||
def install_app(app_name, app_version):
|
def install_app(app_name, app_version):
|
||||||
|
file_path = "/data/apps/running_apps.txt"
|
||||||
|
if os.path.exists(file_path) and os.path.getsize(file_path):
|
||||||
|
ret = Response(code=const.RETURN_SUCCESS, message="已有应用正在启动,请稍后再试")
|
||||||
|
ret = ret.dict()
|
||||||
# check directory
|
# check directory
|
||||||
if docker.check_app_directory(app_name):
|
elif docker.check_app_directory(app_name):
|
||||||
# check port
|
# check port
|
||||||
docker.check_app_compose(app_name)
|
docker.check_app_compose(app_name)
|
||||||
if app_version != None:
|
if app_version != None:
|
||||||
path = "/data/apps/"+app_name+"/.env"
|
path = "/data/apps/"+app_name+"/.env"
|
||||||
docker.modify_env(path, "APP_VERSION", app_version)
|
docker.modify_env(path, "APP_VERSION", app_version)
|
||||||
cmd = "cd /data/apps/"+app_name+" && sudo docker compose up -d"
|
t1 = Thread(target=record_and_install_app, args=(app_name,))
|
||||||
t1 = Thread(target=shell_execute.execute_command_output_all, args=(cmd,))
|
|
||||||
t1.start()
|
t1.start()
|
||||||
ret = Response(code=const.RETURN_SUCCESS, message="应用正在启动中,请过几分钟再查询")
|
ret = Response(code=const.RETURN_SUCCESS, message="应用正在启动中,请过几分钟再查询")
|
||||||
ret = ret.dict()
|
ret = ret.dict()
|
||||||
@ -148,6 +165,16 @@ def install_app(app_name, app_version):
|
|||||||
ret = ret.dict()
|
ret = ret.dict()
|
||||||
return ret
|
return ret
|
||||||
|
|
||||||
|
def record_and_install_app(app_name):
|
||||||
|
# modify running_apps.txt
|
||||||
|
file_path = "/data/apps/running_apps.txt"
|
||||||
|
with open(file_path, "w", encoding="utf-8") as f:
|
||||||
|
f.write(app_name)
|
||||||
|
cmd = "cd /data/apps/" + app_name + " && sudo docker compose up -d"
|
||||||
|
shell_execute.execute_command_output_all(cmd)
|
||||||
|
with open(file_path, "a+", encoding="utf-8") as f:
|
||||||
|
f.truncate(0)
|
||||||
|
|
||||||
def if_app_exits(app_name):
|
def if_app_exits(app_name):
|
||||||
cmd = "docker compose ls -a | grep \'"+app_name+"\\b\'"
|
cmd = "docker compose ls -a | grep \'"+app_name+"\\b\'"
|
||||||
output = shell_execute.execute_command_output_all(cmd)
|
output = shell_execute.execute_command_output_all(cmd)
|
||||||
|
@ -37,30 +37,24 @@ def check_app_directory(app_name):
|
|||||||
def check_app_compose(app_name):
|
def check_app_compose(app_name):
|
||||||
print("checking port...")
|
print("checking port...")
|
||||||
path = "/data/apps/" + app_name + "/.env"
|
path = "/data/apps/" + app_name + "/.env"
|
||||||
http_port = read_env(path, "APP_HTTP_PORT")
|
port_dic = read_env(path, "APP_.*_PORT")
|
||||||
db_port = read_env(path, "APP_DB.*_PORT")
|
|
||||||
#1.判断/data/apps/app_name/.env中的port是否占用,没有被占用,方法结束(network.py的get_start_port方法)
|
#1.判断/data/apps/app_name/.env中的port是否占用,没有被占用,方法结束(network.py的get_start_port方法)
|
||||||
if http_port != "":
|
for port_name in port_dic:
|
||||||
print("check http port...")
|
port_value = network.get_start_port(port_dic[port_name])
|
||||||
http_port = network.get_start_port(http_port)
|
modify_env(path, port_name, port_value)
|
||||||
modify_env(path, "APP_HTTP_PORT", http_port)
|
|
||||||
if db_port != "":
|
|
||||||
print("check db port...")
|
|
||||||
db_port = network.get_start_port(db_port)
|
|
||||||
modify_env(path, "APP_DB.*_PORT", db_port)
|
|
||||||
print("port check complete")
|
print("port check complete")
|
||||||
return
|
return
|
||||||
|
|
||||||
def read_env(path, key):
|
def read_env(path, key):
|
||||||
output = shell_execute.execute_command_output_all("cat " + path + "|grep "+ key+ "|head -1")
|
output = shell_execute.execute_command_output_all("cat " + path + "|grep "+ key)
|
||||||
code = output["code"]
|
code = output["code"]
|
||||||
ret = "" #the value of environment var
|
env_dic = {}
|
||||||
if int(code) == 0 and output["result"] != "":
|
if int(code) == 0 and output["result"] != "":
|
||||||
ret = output["result"]
|
ret = output["result"]
|
||||||
ret = ret.split("=")[1]
|
env_list = ret.split()
|
||||||
ret = re.sub("'","",ret)
|
for env in env_list:
|
||||||
ret = re.sub("\n","",ret)
|
env_dic[env.split("=")[0]] = env.split("=")[1]
|
||||||
return ret
|
return env_dic
|
||||||
|
|
||||||
def modify_env(path, env_name, value):
|
def modify_env(path, env_name, value):
|
||||||
file_data = ""
|
file_data = ""
|
||||||
|
Loading…
Reference in New Issue
Block a user