From b1206c5b3d503eb82770e3048a0564fa41b4412d Mon Sep 17 00:00:00 2001 From: jbirddog <100367399+jbirddog@users.noreply.github.com> Date: Wed, 27 Dec 2023 11:50:01 -0500 Subject: [PATCH] Drop __annotations__ from task data (#834) --- .../services/process_instance_processor.py | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/spiffworkflow-backend/src/spiffworkflow_backend/services/process_instance_processor.py b/spiffworkflow-backend/src/spiffworkflow_backend/services/process_instance_processor.py index 64aac4e62..faf3b42b8 100644 --- a/spiffworkflow-backend/src/spiffworkflow_backend/services/process_instance_processor.py +++ b/spiffworkflow-backend/src/spiffworkflow_backend/services/process_instance_processor.py @@ -160,6 +160,7 @@ class MissingProcessInfoError(Exception): class TaskDataBasedScriptEngineEnvironment(TaskDataEnvironment): # type: ignore def __init__(self, environment_globals: dict[str, Any]): self._last_result: dict[str, Any] = {} + self._non_user_defined_keys = {"__annotations__"} super().__init__(environment_globals) def execute( @@ -169,6 +170,9 @@ class TaskDataBasedScriptEngineEnvironment(TaskDataEnvironment): # type: ignore external_context: dict[str, Any] | None = None, ) -> bool: super().execute(script, context, external_context) + for key in self._non_user_defined_keys: + if key in context: + context.pop(key) self._last_result = context return True @@ -199,7 +203,7 @@ class NonTaskDataBasedScriptEngineEnvironment(BasePythonScriptEngineEnvironment) def __init__(self, environment_globals: dict[str, Any]): self.state: dict[str, Any] = {} - self.non_user_defined_keys = set([*environment_globals.keys()] + ["__builtins__"]) + self.non_user_defined_keys = set([*environment_globals.keys()] + ["__builtins__", "__annotations__"]) super().__init__(environment_globals) def evaluate(