From 6c156380f926e8c5ce90ab470771b120a4d0b51a Mon Sep 17 00:00:00 2001 From: JeLuF Date: Sat, 19 Nov 2022 17:10:45 +0100 Subject: [PATCH] Add network settings to the UI Allow users to choose the uvicorn port Allow users to restrict uvicorn to only listen on localhost --- ui/media/js/parameters.js | 50 ++++++++++++++++++++++++++++++++------- ui/server.py | 40 +++++++++++++++++++++++-------- 2 files changed, 72 insertions(+), 18 deletions(-) diff --git a/ui/media/js/parameters.js b/ui/media/js/parameters.js index d592576d..2e5bc75c 100644 --- a/ui/media/js/parameters.js +++ b/ui/media/js/parameters.js @@ -114,6 +114,24 @@ var PARAMETERS = [ icon: "fa-gear", default: true, }, + { + id: "listen_to_network", + type: ParameterType.checkbox, + label: "Make Stable Diffusion available on your network", + note: "Other devices on your network can access this web page", + icon: "fa-network-wired", + default: true, + }, + { + id: "listen_port", + type: ParameterType.custom, + label: "Network port", + note: "Port that this server listens to. The '9000' part in 'http://localhost:9000'", + icon: "fa-anchor", + render: (parameter) => { + return `` + } + }, { id: "use_beta_channel", type: ParameterType.checkbox, @@ -176,6 +194,8 @@ let useGPUsField = document.querySelector('#use_gpus') let useFullPrecisionField = document.querySelector('#use_full_precision') let saveToDiskField = document.querySelector('#save_to_disk') let diskPathField = document.querySelector('#diskPath') +let listenToNetworkField = document.querySelector("#listen_to_network") +let listenPortField = document.querySelector("#listen_port") let useBetaChannelField = document.querySelector("#use_beta_channel") let uiOpenBrowserOnStartField = document.querySelector("#ui_open_browser_on_start") @@ -205,11 +225,17 @@ async function getAppConfig() { if (config.update_branch === 'beta') { useBetaChannelField.checked = true - document.querySelector("#updateBranchLabel").innerText = "(beta)" + document.querySelector("#updateBranchLabel").innerText = "(beta)" } if (config.ui && config.ui.open_browser_on_start === false) { uiOpenBrowserOnStartField.checked = false } + if (config.net && config.net.listen_to_network === false) { + listenToNetworkField.checked = false + } + if (config.net && config.net.listen_port !== undefined) { + listenPortField.value = config.net.listen_port + } console.log('get config status response', config) } catch (e) { @@ -336,12 +362,20 @@ async function getDevices() { saveSettingsBtn.addEventListener('click', function() { let updateBranch = (useBetaChannelField.checked ? 'beta' : 'main') - changeAppConfig({ - 'render_devices': getCurrentRenderDeviceSelection(), - 'update_branch': updateBranch, - 'ui_open_browser_on_start': uiOpenBrowserOnStartField.checked - }) + if (listenPortField.value == '') { + alert('The network port field must not be empty.') + } else if (listenPortField.value<1 || listenPortField.value>65535) { + alert('The network port must be a number from 1 to 65535') + } else { + changeAppConfig({ + 'render_devices': getCurrentRenderDeviceSelection(), + 'update_branch': updateBranch, + 'ui_open_browser_on_start': uiOpenBrowserOnStartField.checked, + 'listen_to_network': listenToNetworkField.checked, + 'listen_port': listenPortField.value + }) + } - saveSettingsBtn.classList.add('active') - asyncDelay(300).then(() => saveSettingsBtn.classList.remove('active')) + saveSettingsBtn.classList.add('active') + asyncDelay(300).then(() => saveSettingsBtn.classList.remove('active')) }) diff --git a/ui/server.py b/ui/server.py index 94b7fce8..61635f18 100644 --- a/ui/server.py +++ b/ui/server.py @@ -83,13 +83,21 @@ def getConfig(default_val=APP_CONFIG_DEFAULTS): if not os.path.exists(config_json_path): return default_val with open(config_json_path, 'r', encoding='utf-8') as f: - return json.load(f) + config = json.load(f) + if 'net' not in config: + config['net'] = {} + if os.getenv('SD_UI_BIND_PORT') is not None: + config['net']['listen_port'] = int(os.getenv('SD_UI_BIND_PORT')) + if os.getenv('SD_UI_BIND_IP') is not None: + config['net']['listen_to_network'] = ( os.getenv('SD_UI_BIND_IP') == '0.0.0.0' ) + return config except Exception as e: print(str(e)) print(traceback.format_exc()) return default_val def setConfig(config): + print( json.dumps(config) ) try: # config.json config_json_path = os.path.join(CONFIG_DIR, 'config.json') with open(config_json_path, 'w', encoding='utf-8') as f: @@ -103,10 +111,10 @@ def setConfig(config): if 'update_branch' in config: config_bat.append(f"@set update_branch={config['update_branch']}") - if os.getenv('SD_UI_BIND_PORT') is not None: - config_bat.append(f"@set SD_UI_BIND_PORT={os.getenv('SD_UI_BIND_PORT')}") - if os.getenv('SD_UI_BIND_IP') is not None: - config_bat.append(f"@set SD_UI_BIND_IP={os.getenv('SD_UI_BIND_IP')}") + + config_bat.append(f"@set SD_UI_BIND_PORT={config['net']['listen_port']}") + bind_ip = '0.0.0.0' if config['net']['listen_to_network'] else '127.0.0.1' + config_bat.append(f"@set SD_UI_BIND_IP={bind_ip}") if len(config_bat) > 0: with open(config_bat_path, 'w', encoding='utf-8') as f: @@ -120,10 +128,10 @@ def setConfig(config): if 'update_branch' in config: config_sh.append(f"export update_branch={config['update_branch']}") - if os.getenv('SD_UI_BIND_PORT') is not None: - config_sh.append(f"export SD_UI_BIND_PORT={os.getenv('SD_UI_BIND_PORT')}") - if os.getenv('SD_UI_BIND_IP') is not None: - config_sh.append(f"export SD_UI_BIND_IP={os.getenv('SD_UI_BIND_IP')}") + + config_sh.append(f"export SD_UI_BIND_PORT={config['net']['listen_port']}") + bind_ip = '0.0.0.0' if config['net']['listen_to_network'] else '127.0.0.1' + config_sh.append(f"export SD_UI_BIND_IP={bind_ip}") if len(config_sh) > 1: with open(config_sh_path, 'w', encoding='utf-8') as f: @@ -178,6 +186,8 @@ class SetAppConfigRequest(BaseModel): render_devices: Union[List[str], List[int], str, int] = None model_vae: str = None ui_open_browser_on_start: bool = None + listen_to_network: bool = None + listen_port: int = None @app.post('/app_config') async def setAppConfig(req : SetAppConfigRequest): @@ -190,6 +200,14 @@ async def setAppConfig(req : SetAppConfigRequest): if 'ui' not in config: config['ui'] = {} config['ui']['open_browser_on_start'] = req.ui_open_browser_on_start + if req.listen_to_network is not None: + if 'net' not in config: + config['net'] = {} + config['net']['listen_to_network'] = bool(req.listen_to_network) + if req.listen_port is not None: + if 'net' not in config: + config['net'] = {} + config['net']['listen_port'] = int(req.listen_port) try: setConfig(config) @@ -435,7 +453,9 @@ update_render_threads() def open_browser(): config = getConfig() ui = config.get('ui', {}) + net = config.get('net', {'listen_port':9000}) + port = net.get('listen_port', 9000) if ui.get('open_browser_on_start', True): - import webbrowser; webbrowser.open('http://localhost:9000') + import webbrowser; webbrowser.open(f"http://localhost:{port}") open_browser()