ComfyUI-Manager/tests/e2e/scripts/start_comfyui_strict.sh
Dr.Lt.Data 4410ebc6a6
Some checks are pending
Publish to PyPI / build-and-publish (push) Waiting to run
Python Linting / Run Ruff (push) Waiting to run
fix(security): harden CSRF with Content-Type gate and expand E2E coverage (#2818)
Defense-in-depth over GET→POST alone: reject the three CORS-safelisted
simple-form Content-Types (x-www-form-urlencoded, multipart/form-data,
text/plain) on 16 no-body POST handlers (glob + legacy) to block
<form method=POST> CSRF that bypasses method-only gating. Move
comfyui_switch_version to a JSON body so the preflight requirement applies.
Split db_mode/policy/update/channel_url_list into GET(read) + POST(write).
Tighten do_fix (high → high+) and gate three previously-ungated config
setters at middle. Resynchronize openapi.yaml (27 paths, 30 operations,
ComfyUISwitchVersionParams as a shared $ref component). Add E2E harness
variants, Playwright config, CSRF/secgate suites, 39-endpoint coverage,
and a CHANGELOG.

Breaking: legacy per-op POST routes (install/uninstall/fix/disable/update/
reinstall/abort_current) are removed; callers already use queue/batch.
Legacy /manager/notice (v1) is removed; /v2/manager/notice is retained.

Reported-by: XlabAI Team of Tencent Xuanwu Lab
CVSS: 8.1 (AV:N/AC:L/PR:N/UI:R/S:U/C:N/I:H/A:H)
2026-04-22 05:04:30 +09:00

67 lines
2.8 KiB
Bash
Executable File

#!/usr/bin/env bash
# start_comfyui_strict.sh — Launch ComfyUI in STRICT security mode for SECGATE tests.
#
# Patches `security_level = strong` into the manager config.ini before launching
# (with backup of original value), then delegates to start_comfyui.sh. The
# corresponding stop_comfyui.sh teardown should be paired with restore_config()
# inside the pytest fixture (this script does NOT restore on its own — restore
# happens at fixture teardown to keep this wrapper symmetric with
# start_comfyui_legacy.sh).
#
# Why strict mode is needed:
# Several state-changing endpoints (snapshot/remove [middle], snapshot/restore
# [middle+], reboot [middle], queue/update_all [middle+]) check
# is_allowed_security_level(<gate>). At the default `security_level = normal`
# (and is_local_mode = True since we listen on 127.0.0.1), middle and middle+
# operations are ALLOWED — so the 403 path is unreachable. Setting
# security_level = strong puts NORMAL out of the allowed sets and makes the
# 403 contract observable.
#
# At-or-below `normal` configurations cannot test the 403 path for these gates;
# `strong` is required.
#
# Input env vars (forwarded to start_comfyui.sh):
# E2E_ROOT — required
# PORT — default 8199
# TIMEOUT — default 120
#
# Output (last line on success, inherited from start_comfyui.sh):
# COMFYUI_PID=<pid> PORT=<port>
#
# Exit: 0=ready, 1=timeout/failure
#
# Side effect: $E2E_ROOT/comfyui/user/__manager/config.ini gets
# `security_level = strong`. The original value is preserved at
# config.ini.before-strict for the fixture to restore on teardown.
set -euo pipefail
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
[[ -n "${E2E_ROOT:-}" ]] || { echo "[start_comfyui_strict] ERROR: E2E_ROOT is not set" >&2; exit 1; }
CONFIG="$E2E_ROOT/comfyui/user/__manager/config.ini"
BACKUP="$CONFIG.before-strict"
[[ -f "$CONFIG" ]] || { echo "[start_comfyui_strict] ERROR: config not found at $CONFIG" >&2; exit 1; }
# Preserve original config so the fixture can restore it on teardown.
# If a previous run left a backup, do NOT overwrite (preserves the *true*
# pre-strict baseline across crashed test runs).
if [[ ! -f "$BACKUP" ]]; then
cp "$CONFIG" "$BACKUP"
echo "[start_comfyui_strict] Backed up original config to $BACKUP"
fi
# Patch security_level to strong (idempotent — works whether the line is
# already `strong`, `normal`, or any other value).
if grep -qE '^security_level\s*=' "$CONFIG"; then
sed -i -E 's/^security_level\s*=.*/security_level = strong/' "$CONFIG"
else
# security_level missing entirely (unusual) — append under [default]
sed -i -E '/^\[default\]/a security_level = strong' "$CONFIG"
fi
echo "[start_comfyui_strict] Patched security_level = strong in $CONFIG"
exec bash "$SCRIPT_DIR/start_comfyui.sh" "$@"