Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
ninjaneural
GitHub Repository: ninjaneural/webui
Path: blob/master/misc/direct/forge/webui.py
3275 views
1
from __future__ import annotations
2
3
import os
4
import time
5
6
from modules import timer
7
from modules import initialize_util
8
from modules import initialize
9
10
from modules_forge.initialization import initialize_forge
11
12
startup_timer = timer.startup_timer
13
startup_timer.record("launcher")
14
15
initialize_forge()
16
17
initialize.imports()
18
19
initialize.check_versions()
20
21
22
def create_api(app):
23
from modules.api.api import Api
24
from modules.call_queue import queue_lock
25
26
api = Api(app, queue_lock)
27
return api
28
29
30
def api_only():
31
from fastapi import FastAPI
32
from modules.shared_cmd_options import cmd_opts
33
34
initialize.initialize()
35
36
app = FastAPI()
37
initialize_util.setup_middleware(app)
38
api = create_api(app)
39
40
from modules import script_callbacks
41
script_callbacks.before_ui_callback()
42
script_callbacks.app_started_callback(None, app)
43
44
print(f"Startup time: {startup_timer.summary()}.")
45
api.launch(
46
server_name=initialize_util.gradio_server_name(),
47
port=cmd_opts.port if cmd_opts.port else 7861,
48
root_path=f"/{cmd_opts.subpath}" if cmd_opts.subpath else ""
49
)
50
51
52
def webui():
53
from modules.shared_cmd_options import cmd_opts
54
55
launch_api = cmd_opts.api
56
initialize.initialize()
57
58
from modules import shared, ui_tempdir, script_callbacks, ui, progress, ui_extra_networks
59
60
while 1:
61
if shared.opts.clean_temp_dir_at_start:
62
ui_tempdir.cleanup_tmpdr()
63
startup_timer.record("cleanup temp dir")
64
65
script_callbacks.before_ui_callback()
66
startup_timer.record("scripts before_ui_callback")
67
68
shared.demo = ui.create_ui()
69
startup_timer.record("create ui")
70
71
if not cmd_opts.no_gradio_queue:
72
shared.demo.queue(64)
73
74
gradio_auth_creds = list(initialize_util.get_gradio_auth_creds()) or None
75
76
auto_launch_browser = False
77
if os.getenv('SD_WEBUI_RESTARTING') != '1':
78
if shared.opts.auto_launch_browser == "Remote" or cmd_opts.autolaunch:
79
auto_launch_browser = True
80
elif shared.opts.auto_launch_browser == "Local":
81
auto_launch_browser = not cmd_opts.webui_is_non_local
82
83
app, local_url, share_url = shared.demo.launch(
84
share=cmd_opts.share,
85
server_name=initialize_util.gradio_server_name(),
86
server_port=cmd_opts.port,
87
ssl_keyfile=cmd_opts.tls_keyfile,
88
ssl_certfile=cmd_opts.tls_certfile,
89
ssl_verify=cmd_opts.disable_tls_verify,
90
debug=cmd_opts.gradio_debug,
91
auth=gradio_auth_creds,
92
inbrowser=auto_launch_browser,
93
prevent_thread_lock=True,
94
allowed_paths=cmd_opts.gradio_allowed_path,
95
app_kwargs={
96
"docs_url": "/docs",
97
"redoc_url": "/redoc",
98
},
99
root_path=f"/{cmd_opts.subpath}" if cmd_opts.subpath else "",
100
)
101
102
startup_timer.record("gradio launch")
103
104
# gradio uses a very open CORS policy via app.user_middleware, which makes it possible for
105
# an attacker to trick the user into opening a malicious HTML page, which makes a request to the
106
# running web ui and do whatever the attacker wants, including installing an extension and
107
# running its code. We disable this here. Suggested by RyotaK.
108
app.user_middleware = [x for x in app.user_middleware if x.cls.__name__ != 'CORSMiddleware']
109
110
initialize_util.setup_middleware(app)
111
112
progress.setup_progress_api(app)
113
ui.setup_ui_api(app)
114
115
if launch_api:
116
create_api(app)
117
118
ui_extra_networks.add_pages_to_demo(app)
119
120
startup_timer.record("add APIs")
121
122
with startup_timer.subcategory("app_started_callback"):
123
script_callbacks.app_started_callback(shared.demo, app)
124
125
timer.startup_record = startup_timer.dump()
126
print(f"Startup time: {startup_timer.summary()}.")
127
128
try:
129
while True:
130
server_command = shared.state.wait_for_server_command(timeout=5)
131
if server_command:
132
if server_command in ("stop", "restart"):
133
break
134
else:
135
print(f"Unknown server command: {server_command}")
136
except KeyboardInterrupt:
137
print('Caught KeyboardInterrupt, stopping...')
138
server_command = "stop"
139
140
if server_command == "stop":
141
print("Stopping server...")
142
# If we catch a keyboard interrupt, we want to stop the server and exit.
143
shared.demo.close()
144
break
145
146
# disable auto launch webui in browser for subsequent UI Reload
147
os.environ.setdefault('SD_WEBUI_RESTARTING', '1')
148
149
print('Restarting UI...')
150
shared.demo.close()
151
time.sleep(0.5)
152
startup_timer.reset()
153
script_callbacks.app_reload_callback()
154
startup_timer.record("app reload callback")
155
script_callbacks.script_unloaded_callback()
156
startup_timer.record("scripts unloaded callback")
157
initialize.initialize_rest(reload_script_modules=True)
158
159
160
if __name__ == "__main__":
161
from modules.shared_cmd_options import cmd_opts
162
163
if cmd_opts.nowebui:
164
api_only()
165
else:
166
webui()
167
168