mirror of
https://github.com/AUTOMATIC1111/stable-diffusion-webui.git
synced 2025-02-07 22:22:53 +08:00
Get API working
Docs still doesn't work.
This commit is contained in:
parent
4e8dfa3af5
commit
43e893ce2a
@ -92,7 +92,7 @@ class PydanticModelGenerator:
|
|||||||
fields = {
|
fields = {
|
||||||
d.field: (d.field_type, Field(default=d.field_value, alias=d.field_alias, exclude=d.field_exclude)) for d in self._model_def
|
d.field: (d.field_type, Field(default=d.field_value, alias=d.field_alias, exclude=d.field_exclude)) for d in self._model_def
|
||||||
}
|
}
|
||||||
DynamicModel = create_model(self._model_name, __config__=ConfigDict(populate_by_name=True, frozen=True), **fields)
|
DynamicModel = create_model(self._model_name, __config__=ConfigDict(populate_by_name=True, frozen=False), **fields)
|
||||||
return DynamicModel
|
return DynamicModel
|
||||||
|
|
||||||
StableDiffusionTxt2ImgProcessingAPI = PydanticModelGenerator(
|
StableDiffusionTxt2ImgProcessingAPI = PydanticModelGenerator(
|
||||||
@ -100,13 +100,13 @@ StableDiffusionTxt2ImgProcessingAPI = PydanticModelGenerator(
|
|||||||
StableDiffusionProcessingTxt2Img,
|
StableDiffusionProcessingTxt2Img,
|
||||||
[
|
[
|
||||||
{"key": "sampler_index", "type": str, "default": "Euler"},
|
{"key": "sampler_index", "type": str, "default": "Euler"},
|
||||||
{"key": "script_name", "type": str, "default": None},
|
{"key": "script_name", "type": str | None, "default": None},
|
||||||
{"key": "script_args", "type": list, "default": []},
|
{"key": "script_args", "type": list, "default": []},
|
||||||
{"key": "send_images", "type": bool, "default": True},
|
{"key": "send_images", "type": bool, "default": True},
|
||||||
{"key": "save_images", "type": bool, "default": False},
|
{"key": "save_images", "type": bool, "default": False},
|
||||||
{"key": "alwayson_scripts", "type": dict, "default": {}},
|
{"key": "alwayson_scripts", "type": dict, "default": {}},
|
||||||
{"key": "force_task_id", "type": str, "default": None},
|
{"key": "force_task_id", "type": str | None, "default": None},
|
||||||
{"key": "infotext", "type": str, "default": None},
|
{"key": "infotext", "type": str | None, "default": None},
|
||||||
]
|
]
|
||||||
).generate_model()
|
).generate_model()
|
||||||
|
|
||||||
@ -115,27 +115,27 @@ StableDiffusionImg2ImgProcessingAPI = PydanticModelGenerator(
|
|||||||
StableDiffusionProcessingImg2Img,
|
StableDiffusionProcessingImg2Img,
|
||||||
[
|
[
|
||||||
{"key": "sampler_index", "type": str, "default": "Euler"},
|
{"key": "sampler_index", "type": str, "default": "Euler"},
|
||||||
{"key": "init_images", "type": list, "default": None},
|
{"key": "init_images", "type": list, "default": []},
|
||||||
{"key": "denoising_strength", "type": float, "default": 0.75},
|
{"key": "denoising_strength", "type": float, "default": 0.75},
|
||||||
{"key": "mask", "type": str, "default": None},
|
{"key": "mask", "type": str | None, "default": None},
|
||||||
{"key": "include_init_images", "type": bool, "default": False, "exclude" : True},
|
{"key": "include_init_images", "type": bool, "default": False, "exclude" : True},
|
||||||
{"key": "script_name", "type": str, "default": None},
|
{"key": "script_name", "type": str | None, "default": None},
|
||||||
{"key": "script_args", "type": list, "default": []},
|
{"key": "script_args", "type": list, "default": []},
|
||||||
{"key": "send_images", "type": bool, "default": True},
|
{"key": "send_images", "type": bool, "default": True},
|
||||||
{"key": "save_images", "type": bool, "default": False},
|
{"key": "save_images", "type": bool, "default": False},
|
||||||
{"key": "alwayson_scripts", "type": dict, "default": {}},
|
{"key": "alwayson_scripts", "type": dict, "default": {}},
|
||||||
{"key": "force_task_id", "type": str, "default": None},
|
{"key": "force_task_id", "type": str | None, "default": None},
|
||||||
{"key": "infotext", "type": str, "default": None},
|
{"key": "infotext", "type": str | None, "default": None},
|
||||||
]
|
]
|
||||||
).generate_model()
|
).generate_model()
|
||||||
|
|
||||||
class TextToImageResponse(BaseModel):
|
class TextToImageResponse(BaseModel):
|
||||||
images: list[str] = Field(default=None, title="Image", description="The generated image in base64 format.")
|
images: list[str] | None = Field(default=None, title="Image", description="The generated image in base64 format.")
|
||||||
parameters: dict
|
parameters: dict
|
||||||
info: str
|
info: str
|
||||||
|
|
||||||
class ImageToImageResponse(BaseModel):
|
class ImageToImageResponse(BaseModel):
|
||||||
images: list[str] = Field(default=None, title="Image", description="The generated image in base64 format.")
|
images: list[str] | None = Field(default=None, title="Image", description="The generated image in base64 format.")
|
||||||
parameters: dict
|
parameters: dict
|
||||||
info: str
|
info: str
|
||||||
|
|
||||||
@ -161,7 +161,7 @@ class ExtrasSingleImageRequest(ExtrasBaseRequest):
|
|||||||
image: str = Field(default="", title="Image", description="Image to work on, must be a Base64 string containing the image's data.")
|
image: str = Field(default="", title="Image", description="Image to work on, must be a Base64 string containing the image's data.")
|
||||||
|
|
||||||
class ExtrasSingleImageResponse(ExtraBaseResponse):
|
class ExtrasSingleImageResponse(ExtraBaseResponse):
|
||||||
image: str = Field(default=None, title="Image", description="The generated image in base64 format.")
|
image: str | None = Field(default=None, title="Image", description="The generated image in base64 format.")
|
||||||
|
|
||||||
class FileData(BaseModel):
|
class FileData(BaseModel):
|
||||||
data: str = Field(title="File data", description="Base64 representation of the file")
|
data: str = Field(title="File data", description="Base64 representation of the file")
|
||||||
@ -188,15 +188,15 @@ class ProgressResponse(BaseModel):
|
|||||||
progress: float = Field(title="Progress", description="The progress with a range of 0 to 1")
|
progress: float = Field(title="Progress", description="The progress with a range of 0 to 1")
|
||||||
eta_relative: float = Field(title="ETA in secs")
|
eta_relative: float = Field(title="ETA in secs")
|
||||||
state: dict = Field(title="State", description="The current state snapshot")
|
state: dict = Field(title="State", description="The current state snapshot")
|
||||||
current_image: str = Field(default=None, title="Current image", description="The current image in base64 format. opts.show_progress_every_n_steps is required for this to work.")
|
current_image: str | None = Field(default=None, title="Current image", description="The current image in base64 format. opts.show_progress_every_n_steps is required for this to work.")
|
||||||
textinfo: str = Field(default=None, title="Info text", description="Info text used by WebUI.")
|
textinfo: str | None = Field(default=None, title="Info text", description="Info text used by WebUI.")
|
||||||
|
|
||||||
class InterrogateRequest(BaseModel):
|
class InterrogateRequest(BaseModel):
|
||||||
image: str = Field(default="", title="Image", description="Image to work on, must be a Base64 string containing the image's data.")
|
image: str = Field(default="", title="Image", description="Image to work on, must be a Base64 string containing the image's data.")
|
||||||
model: str = Field(default="clip", title="Model", description="The interrogate model used.")
|
model: str = Field(default="clip", title="Model", description="The interrogate model used.")
|
||||||
|
|
||||||
class InterrogateResponse(BaseModel):
|
class InterrogateResponse(BaseModel):
|
||||||
caption: str = Field(default=None, title="Caption", description="The generated caption for the image.")
|
caption: str | None = Field(default=None, title="Caption", description="The generated caption for the image.")
|
||||||
|
|
||||||
class TrainResponse(BaseModel):
|
class TrainResponse(BaseModel):
|
||||||
info: str = Field(title="Train info", description="Response string from train embedding or hypernetwork task.")
|
info: str = Field(title="Train info", description="Response string from train embedding or hypernetwork task.")
|
||||||
@ -221,7 +221,7 @@ _options = vars(parser)['_option_string_actions']
|
|||||||
for key in _options:
|
for key in _options:
|
||||||
if(_options[key].dest != 'help'):
|
if(_options[key].dest != 'help'):
|
||||||
flag = _options[key]
|
flag = _options[key]
|
||||||
_type = str
|
_type = str | None
|
||||||
if _options[key].default is not None:
|
if _options[key].default is not None:
|
||||||
_type = type(_options[key].default)
|
_type = type(_options[key].default)
|
||||||
flags.update({flag.dest: (_type, Field(default=flag.default, description=flag.help))})
|
flags.update({flag.dest: (_type, Field(default=flag.default, description=flag.help))})
|
||||||
@ -231,7 +231,7 @@ FlagsModel = create_model("Flags", **flags)
|
|||||||
class SamplerItem(BaseModel):
|
class SamplerItem(BaseModel):
|
||||||
name: str = Field(title="Name")
|
name: str = Field(title="Name")
|
||||||
aliases: list[str] = Field(title="Aliases")
|
aliases: list[str] = Field(title="Aliases")
|
||||||
options: dict[str, str] = Field(title="Options")
|
options: dict[str, Any] = Field(title="Options")
|
||||||
|
|
||||||
class SchedulerItem(BaseModel):
|
class SchedulerItem(BaseModel):
|
||||||
name: str = Field(title="Name")
|
name: str = Field(title="Name")
|
||||||
@ -307,12 +307,12 @@ class MemoryResponse(BaseModel):
|
|||||||
|
|
||||||
|
|
||||||
class ScriptsList(BaseModel):
|
class ScriptsList(BaseModel):
|
||||||
txt2img: list = Field(default=None, title="Txt2img", description="Titles of scripts (txt2img)")
|
txt2img: list | None = Field(default=None, title="Txt2img", description="Titles of scripts (txt2img)")
|
||||||
img2img: list = Field(default=None, title="Img2img", description="Titles of scripts (img2img)")
|
img2img: list | None = Field(default=None, title="Img2img", description="Titles of scripts (img2img)")
|
||||||
|
|
||||||
|
|
||||||
class ScriptArg(BaseModel):
|
class ScriptArg(BaseModel):
|
||||||
label: str = Field(default=None, title="Label", description="Name of the argument in UI")
|
label: str | None = Field(default=None, title="Label", description="Name of the argument in UI")
|
||||||
value: Optional[Any] = Field(default=None, title="Value", description="Default value of the argument")
|
value: Optional[Any] = Field(default=None, title="Value", description="Default value of the argument")
|
||||||
minimum: Optional[Any] = Field(default=None, title="Minimum", description="Minimum allowed value for the argumentin UI")
|
minimum: Optional[Any] = Field(default=None, title="Minimum", description="Minimum allowed value for the argumentin UI")
|
||||||
maximum: Optional[Any] = Field(default=None, title="Minimum", description="Maximum allowed value for the argumentin UI")
|
maximum: Optional[Any] = Field(default=None, title="Minimum", description="Maximum allowed value for the argumentin UI")
|
||||||
@ -321,9 +321,9 @@ class ScriptArg(BaseModel):
|
|||||||
|
|
||||||
|
|
||||||
class ScriptInfo(BaseModel):
|
class ScriptInfo(BaseModel):
|
||||||
name: str = Field(default=None, title="Name", description="Script name")
|
name: str | None = Field(default=None, title="Name", description="Script name")
|
||||||
is_alwayson: bool = Field(default=None, title="IsAlwayson", description="Flag specifying whether this script is an alwayson script")
|
is_alwayson: bool | None = Field(default=None, title="IsAlwayson", description="Flag specifying whether this script is an alwayson script")
|
||||||
is_img2img: bool = Field(default=None, title="IsImg2img", description="Flag specifying whether this script is an img2img script")
|
is_img2img: bool | None = Field(default=None, title="IsImg2img", description="Flag specifying whether this script is an img2img script")
|
||||||
args: list[ScriptArg] = Field(title="Arguments", description="List of script's arguments")
|
args: list[ScriptArg] = Field(title="Arguments", description="List of script's arguments")
|
||||||
|
|
||||||
class ExtensionItem(BaseModel):
|
class ExtensionItem(BaseModel):
|
||||||
|
Loading…
Reference in New Issue
Block a user