dify/api/tests
Devbyteai 26444d8b6c fix(template-transform): use base64 encoding for Jinja2 templates
When Jinja2 templates containing special characters (quotes, newlines)
were embedded directly in the generated Python script using triple-quoted
strings, the script would break. This fix encodes the template as base64
before embedding, then decodes it at runtime.

Root cause: Templates were inserted via string replacement into a Python
script like `jinja2.Template('''...''')`. If the template contained `'''`,
the generated script had a syntax error.

Solution: Add serialize_code() method to base64-encode templates, then
override assemble_runner_script() in Jinja2TemplateTransformer to use
the encoded template with runtime decoding.

This specifically affects Jinja2 templates - Python3 and JavaScript
transformers insert user code at the top level (not inside strings),
so they don't have this vulnerability.

Fixes #26818
2025-12-26 20:08:12 +02:00
..
fixtures/workflow fix: workflow end node validate error (#29473) 2025-12-11 13:47:37 +08:00
integration_tests fix(template-transform): use base64 encoding for Jinja2 templates 2025-12-26 20:08:12 +02:00
test_containers_integration_tests fix(template-transform): use base64 encoding for Jinja2 templates 2025-12-26 20:08:12 +02:00
unit_tests fix: fix DatasetRetrieval._process_metadata_filter_func miss in operator (#30199) 2025-12-26 16:34:50 +08:00
__init__.py Initial commit 2023-05-15 08:51:32 +08:00