[7] fix string casting

pull/1018/head
meisnate12 2 years ago
parent 34779702cb
commit 58e8aef2c9

@ -1 +1 @@
1.17.3-develop6 1.17.3-develop7

@ -165,13 +165,16 @@ class DataFile:
for key, value in variables.copy().items(): for key, value in variables.copy().items():
variables[f"{key}_encoded"] = requests.utils.quote(str(value)) variables[f"{key}_encoded"] = requests.utils.quote(str(value))
def replace_var(input_item, search_dict): def replace_var(input_item, search_dicts):
return_item = str(input_item) if not isinstance(search_dicts, list):
for rk, rv in search_dict.items(): search_dicts = [search_dicts]
if f"<<{rk}>>" == return_item: return_item = input_item
return_item = rv for search_dict in search_dicts:
if f"<<{rk}>>" in return_item: for rk, rv in search_dict.items():
return_item = return_item.replace(f"<<{rk}>>", str(rv)) if f"<<{rk}>>" == str(return_item):
return_item = rv
if f"<<{rk}>>" in str(return_item):
return_item = str(return_item).replace(f"<<{rk}>>", str(rv))
return return_item return return_item
ini_default = {} ini_default = {}
@ -213,7 +216,7 @@ class DataFile:
logger.debug(f"Conditional: {con_key}") logger.debug(f"Conditional: {con_key}")
if not isinstance(con_value, dict): if not isinstance(con_value, dict):
raise Failed(f"{self.data_type} Error: template sub-attribute conditionals is not a dictionary") raise Failed(f"{self.data_type} Error: template sub-attribute conditionals is not a dictionary")
final_key = replace_var(replace_var(con_key, variables), default) final_key = replace_var(con_key, [variables, default])
if final_key != con_key: if final_key != con_key:
logger.debug(f"Variable: {final_key}") logger.debug(f"Variable: {final_key}")
if final_key in variables: if final_key in variables:
@ -235,8 +238,8 @@ class DataFile:
for var_key, var_value in condition.items(): for var_key, var_value in condition.items():
if var_key == "value": if var_key == "value":
continue continue
var_key = replace_var(replace_var(var_key, variables), default) var_key = replace_var(var_key, [variables, default])
var_value = replace_var(replace_var(var_value, variables), default) var_value = replace_var(var_value, [variables, default])
if var_key in variables: if var_key in variables:
if (isinstance(var_value, list) and variables[var_key] not in var_value) or \ if (isinstance(var_value, list) and variables[var_key] not in var_value) or \
(not isinstance(var_value, list) and variables[var_key] != var_value): (not isinstance(var_value, list) and variables[var_key] != var_value):

Loading…
Cancel
Save