Fix other apis
This commit is contained in:
parent
75b67eebf2
commit
fcd75bd874
@ -4,7 +4,7 @@ import time
|
|||||||
import uvicorn
|
import uvicorn
|
||||||
from threading import Lock
|
from threading import Lock
|
||||||
from io import BytesIO
|
from io import BytesIO
|
||||||
from gradio.processing_utils import encode_pil_to_base64, decode_base64_to_file, decode_base64_to_image
|
from gradio.processing_utils import decode_base64_to_file
|
||||||
from fastapi import APIRouter, Depends, FastAPI, HTTPException
|
from fastapi import APIRouter, Depends, FastAPI, HTTPException
|
||||||
from fastapi.security import HTTPBasic, HTTPBasicCredentials
|
from fastapi.security import HTTPBasic, HTTPBasicCredentials
|
||||||
from secrets import compare_digest
|
from secrets import compare_digest
|
||||||
@ -41,6 +41,10 @@ def setUpscalers(req: dict):
|
|||||||
reqDict.pop('upscaler_2')
|
reqDict.pop('upscaler_2')
|
||||||
return reqDict
|
return reqDict
|
||||||
|
|
||||||
|
def decode_base64_to_image(encoding):
|
||||||
|
if encoding.startswith("data:image/"):
|
||||||
|
encoding = encoding.split(";")[1].split(",")[1]
|
||||||
|
return Image.open(BytesIO(base64.b64decode(encoding)))
|
||||||
|
|
||||||
def encode_pil_to_base64(image):
|
def encode_pil_to_base64(image):
|
||||||
with io.BytesIO() as output_bytes:
|
with io.BytesIO() as output_bytes:
|
||||||
@ -134,10 +138,7 @@ class Api:
|
|||||||
|
|
||||||
mask = img2imgreq.mask
|
mask = img2imgreq.mask
|
||||||
if mask:
|
if mask:
|
||||||
if mask.startswith("data:image/"):
|
|
||||||
mask = decode_base64_to_image(mask)
|
mask = decode_base64_to_image(mask)
|
||||||
else:
|
|
||||||
mask = Image.open(BytesIO(base64.b64decode(mask)))
|
|
||||||
|
|
||||||
populate = img2imgreq.copy(update={ # Override __init__ params
|
populate = img2imgreq.copy(update={ # Override __init__ params
|
||||||
"sd_model": shared.sd_model,
|
"sd_model": shared.sd_model,
|
||||||
@ -151,10 +152,7 @@ class Api:
|
|||||||
|
|
||||||
imgs = []
|
imgs = []
|
||||||
for img in init_images:
|
for img in init_images:
|
||||||
if img.startswith("data:image/"):
|
|
||||||
img = decode_base64_to_image(img)
|
img = decode_base64_to_image(img)
|
||||||
else:
|
|
||||||
img = Image.open(BytesIO(base64.b64decode(img)))
|
|
||||||
imgs = [img] * p.batch_size
|
imgs = [img] * p.batch_size
|
||||||
|
|
||||||
p.init_images = imgs
|
p.init_images = imgs
|
||||||
|
Loading…
Reference in New Issue
Block a user