From 2836fd1db3efcd5ede63c0e7fbbdf677730dbb51 Mon Sep 17 00:00:00 2001 From: Tuchuanhuhuhu Date: Wed, 18 Sep 2024 09:27:18 +0800 Subject: [PATCH] bugfix: Added additional checks when loading template --- modules/utils.py | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/modules/utils.py b/modules/utils.py index 24afe763..bf7e799a 100644 --- a/modules/utils.py +++ b/modules/utils.py @@ -520,13 +520,17 @@ def filter_history(user_name, keyword): def load_template(filename, mode=0): logging.debug(f"加载模板文件{filename},模式为{mode}(0为返回字典和下拉菜单,1为返回下拉菜单,2为返回字典)") lines = [] + template_file_path = os.path.join(TEMPLATES_DIR, filename) + # check if template_file_path is inside TEMPLATES_DIR + if not os.path.realpath(template_file_path).startswith(os.path.realpath(TEMPLATES_DIR)): + return "Invalid template file path" if filename.endswith(".json"): - with open(os.path.join(TEMPLATES_DIR, filename), "r", encoding="utf8") as f: + with open(template_file_path, "r", encoding="utf8") as f: lines = json.load(f) lines = [[i["act"], i["prompt"]] for i in lines] else: with open( - os.path.join(TEMPLATES_DIR, filename), "r", encoding="utf8" + template_file_path, "r", encoding="utf8" ) as csvfile: reader = csv.reader(csvfile) lines = list(reader)