aboutsummaryrefslogtreecommitdiffstats
path: root/webui.py
diff options
context:
space:
mode:
authorAUTOMATIC <16777216c@gmail.com>2022-11-04 07:07:29 +0000
committerAUTOMATIC <16777216c@gmail.com>2022-11-04 07:07:29 +0000
commit5f0117154382eb0e2547c72630256681673e353b (patch)
tree0779403a529613676d75bce60b44180564ac5fa6 /webui.py
parentf2b69709eaff88fc3a2bd49585556ec0883bf5ea (diff)
downloadstable-diffusion-webui-gfx803-5f0117154382eb0e2547c72630256681673e353b.tar.gz
stable-diffusion-webui-gfx803-5f0117154382eb0e2547c72630256681673e353b.tar.bz2
stable-diffusion-webui-gfx803-5f0117154382eb0e2547c72630256681673e353b.zip
shut down gradio's "everything allowed" CORS policy; I checked the main functionality to work with this, but if this breaks some exotic workflow, I'm sorry.
Diffstat (limited to 'webui.py')
-rw-r--r--webui.py6
1 files changed, 6 insertions, 0 deletions
diff --git a/webui.py b/webui.py
index 3b21c071..81df09dd 100644
--- a/webui.py
+++ b/webui.py
@@ -141,6 +141,12 @@ def webui():
# after initial launch, disable --autolaunch for subsequent restarts
cmd_opts.autolaunch = False
+ # gradio uses a very open CORS policy via app.user_middleware, which makes it possible for
+ # an attacker to trick the user into opening a malicious HTML page, which makes a request to the
+ # running web ui and do whatever the attcker wants, including installing an extension and
+ # runnnig its code. We disable this here. Suggested by RyotaK.
+ app.user_middleware = [x for x in app.user_middleware if x.cls.__name__ != 'CORSMiddleware']
+
app.add_middleware(GZipMiddleware, minimum_size=1000)
if launch_api: