Skip to content

Commit

Permalink
Merge pull request #31 from neXenio/fix/boolean_evaluation
Browse files Browse the repository at this point in the history
fix boolean evaluation for conditional resolvers
  • Loading branch information
MatteoVoges authored Oct 8, 2024
2 parents 2b25c6d + e7bd5d9 commit 839aa8f
Showing 1 changed file with 9 additions and 5 deletions.
14 changes: 9 additions & 5 deletions kapitan/inventory/resolvers.py
Original file line number Diff line number Diff line change
Expand Up @@ -167,30 +167,34 @@ def parent_path(_parent_: Node):
return _parent_._get_flag("path")


def evaluate_bool(condition: str) -> bool:
return str(condition).lower() in ["false", "", "0", "none"]


def condition_if(condition: str, config: dict):
if bool(condition):
if evaluate_bool(condition):
return config
else:
return {}


def condition_if_else(condition: str, config_if: dict, config_else: dict):
if bool(condition):
if evaluate_bool(condition):
return config_if
else:
return config_else


def condition_not(condition: str):
return not bool(condition)
return not evaluate_bool(condition)


def condition_and(*conditions: str):
return all(conditions)
return all(map(evaluate_bool, conditions))


def condition_or(*conditions: str):
return any(conditions)
return any(map(evaluate_bool, conditions))


def condition_equal(*configs):
Expand Down

0 comments on commit 839aa8f

Please sign in to comment.