aboutsummaryrefslogtreecommitdiff
path: root/modules
diff options
context:
space:
mode:
authorAUTOMATIC <16777216c@gmail.com>2023-01-08 16:14:38 +0300
committerAUTOMATIC <16777216c@gmail.com>2023-01-08 16:14:38 +0300
commit137ce534b2355a527cd1a50c192909161258b442 (patch)
treec2945d3ca2a08cccb6e9cf5db622ac6f8f41e8a1 /modules
parente7f2f1e1b6f9d616d2b207e596df859d909ab31b (diff)
remove some code duplication
remove calls to locals() add a test for img2img with script
Diffstat (limited to 'modules')
-rw-r--r--modules/api/api.py33
1 files changed, 16 insertions, 17 deletions
diff --git a/modules/api/api.py b/modules/api/api.py
index 1785a6b4..5b6125f8 100644
--- a/modules/api/api.py
+++ b/modules/api/api.py
@@ -148,14 +148,20 @@ class Api:
raise HTTPException(status_code=401, detail="Incorrect username or password", headers={"WWW-Authenticate": "Basic"})
- def text2imgapi(self, txt2imgreq: StableDiffusionTxt2ImgProcessingAPI):
- if txt2imgreq.script_name is not None:
- if scripts.scripts_txt2img.scripts == []:
- scripts.scripts_txt2img.initialize_scripts(False)
- ui.create_ui()
+ def get_script(self, script_name, script_runner):
+ if script_name is None:
+ return None, None
+
+ if not script_runner.scripts:
+ script_runner.initialize_scripts(False)
+ ui.create_ui()
+
+ script_idx = script_name_to_index(script_name, script_runner.selectable_scripts)
+ script = script_runner.selectable_scripts[script_idx]
+ return script, script_idx
- script_idx = script_name_to_index(txt2imgreq.script_name, scripts.scripts_txt2img.selectable_scripts)
- script = scripts.scripts_txt2img.selectable_scripts[script_idx]
+ def text2imgapi(self, txt2imgreq: StableDiffusionTxt2ImgProcessingAPI):
+ script, script_idx = self.get_script(txt2imgreq.script_name, scripts.scripts_txt2img)
populate = txt2imgreq.copy(update={ # Override __init__ params
"sampler_name": validate_sampler_name(txt2imgreq.sampler_name or txt2imgreq.sampler_index),
@@ -173,7 +179,7 @@ class Api:
p = StableDiffusionProcessingTxt2Img(sd_model=shared.sd_model, **args)
shared.state.begin()
- if 'script' in locals():
+ if script is not None:
p.outpath_grids = opts.outdir_txt2img_grids
p.outpath_samples = opts.outdir_txt2img_samples
p.script_args = [script_idx + 1] + [None] * (script.args_from - 1) + p.script_args
@@ -182,7 +188,6 @@ class Api:
processed = process_images(p)
shared.state.end()
-
b64images = list(map(encode_pil_to_base64, processed.images))
return TextToImageResponse(images=b64images, parameters=vars(txt2imgreq), info=processed.js())
@@ -192,13 +197,7 @@ class Api:
if init_images is None:
raise HTTPException(status_code=404, detail="Init image not found")
- if img2imgreq.script_name is not None:
- if scripts.scripts_img2img.scripts == []:
- scripts.scripts_img2img.initialize_scripts(True)
- ui.create_ui()
-
- script_idx = script_name_to_index(img2imgreq.script_name, scripts.scripts_img2img.selectable_scripts)
- script = scripts.scripts_img2img.selectable_scripts[script_idx]
+ script, script_idx = self.get_script(img2imgreq.script_name, scripts.scripts_img2img)
mask = img2imgreq.mask
if mask:
@@ -223,7 +222,7 @@ class Api:
p.init_images = [decode_base64_to_image(x) for x in init_images]
shared.state.begin()
- if 'script' in locals():
+ if script is not None:
p.outpath_grids = opts.outdir_img2img_grids
p.outpath_samples = opts.outdir_img2img_samples
p.script_args = [script_idx + 1] + [None] * (script.args_from - 1) + p.script_args