2023-02-02 14:31:35 +00:00
|
|
|
from hashlib import sha256
|
2023-02-02 04:20:40 +00:00
|
|
|
from json import dumps
|
2023-02-02 14:31:35 +00:00
|
|
|
from logging import getLogger
|
2023-02-02 04:20:40 +00:00
|
|
|
from PIL import Image
|
2023-02-02 14:31:35 +00:00
|
|
|
from struct import pack
|
|
|
|
from time import time
|
|
|
|
from typing import Any, Optional, Tuple
|
2023-02-02 04:20:40 +00:00
|
|
|
|
|
|
|
from .params import (
|
|
|
|
Border,
|
|
|
|
ImageParams,
|
2023-02-02 14:31:35 +00:00
|
|
|
Param,
|
2023-02-02 04:20:40 +00:00
|
|
|
Size,
|
|
|
|
UpscaleParams,
|
|
|
|
)
|
|
|
|
from .utils import (
|
|
|
|
base_join,
|
|
|
|
ServerContext,
|
|
|
|
)
|
|
|
|
|
2023-02-02 14:31:35 +00:00
|
|
|
logger = getLogger(__name__)
|
|
|
|
|
2023-02-02 14:47:37 +00:00
|
|
|
|
2023-02-02 14:31:35 +00:00
|
|
|
def hash_value(sha, param: Param):
|
|
|
|
if param is None:
|
|
|
|
return
|
|
|
|
elif isinstance(param, float):
|
|
|
|
sha.update(bytearray(pack('!f', param)))
|
|
|
|
elif isinstance(param, int):
|
|
|
|
sha.update(bytearray(pack('!I', param)))
|
|
|
|
elif isinstance(param, str):
|
|
|
|
sha.update(param.encode('utf-8'))
|
|
|
|
else:
|
|
|
|
logger.warn('cannot hash param: %s, %s', param, type(param))
|
|
|
|
|
2023-02-02 04:20:40 +00:00
|
|
|
|
|
|
|
def json_params(
|
|
|
|
output: str,
|
|
|
|
params: ImageParams,
|
|
|
|
size: Size,
|
|
|
|
upscale: Optional[UpscaleParams] = None,
|
|
|
|
border: Optional[Border] = None,
|
|
|
|
) -> Any:
|
2023-02-02 04:31:01 +00:00
|
|
|
json = {
|
|
|
|
'output': output,
|
|
|
|
'params': params.tojson(),
|
|
|
|
}
|
|
|
|
|
2023-02-02 04:25:53 +00:00
|
|
|
if upscale is not None and border is not None:
|
|
|
|
size = upscale.resize(size.add_border(border))
|
|
|
|
|
|
|
|
if upscale is not None:
|
2023-02-02 04:31:01 +00:00
|
|
|
json['upscale'] = upscale.tojson()
|
2023-02-02 04:25:53 +00:00
|
|
|
size = upscale.resize(size)
|
|
|
|
|
|
|
|
if border is not None:
|
2023-02-02 04:31:01 +00:00
|
|
|
json['border'] = border.tojson()
|
2023-02-02 04:25:53 +00:00
|
|
|
size = size.add_border(border)
|
|
|
|
|
2023-02-02 04:37:26 +00:00
|
|
|
json['size'] = size.tojson()
|
2023-02-02 04:31:01 +00:00
|
|
|
|
2023-02-02 04:35:10 +00:00
|
|
|
return json
|
2023-02-02 04:20:40 +00:00
|
|
|
|
|
|
|
|
2023-02-02 14:31:35 +00:00
|
|
|
def make_output_name(
|
2023-02-02 14:47:37 +00:00
|
|
|
ctx: ServerContext,
|
2023-02-02 14:31:35 +00:00
|
|
|
mode: str,
|
|
|
|
params: ImageParams,
|
|
|
|
size: Size,
|
|
|
|
extras: Optional[Tuple[Param]] = None
|
|
|
|
) -> str:
|
|
|
|
now = int(time())
|
|
|
|
sha = sha256()
|
|
|
|
|
|
|
|
hash_value(sha, mode)
|
|
|
|
hash_value(sha, params.model)
|
|
|
|
hash_value(sha, params.provider)
|
|
|
|
hash_value(sha, params.scheduler.__name__)
|
|
|
|
hash_value(sha, params.prompt)
|
|
|
|
hash_value(sha, params.negative_prompt)
|
|
|
|
hash_value(sha, params.cfg)
|
|
|
|
hash_value(sha, params.steps)
|
|
|
|
hash_value(sha, params.seed)
|
|
|
|
hash_value(sha, size.width)
|
|
|
|
hash_value(sha, size.height)
|
|
|
|
|
|
|
|
if extras is not None:
|
|
|
|
for param in extras:
|
|
|
|
hash_value(sha, param)
|
|
|
|
|
2023-02-02 14:47:37 +00:00
|
|
|
return '%s_%s_%s_%s.%s' % (mode, params.seed, sha.hexdigest(), now, ctx.image_format)
|
2023-02-02 14:31:35 +00:00
|
|
|
|
|
|
|
|
2023-02-02 04:20:40 +00:00
|
|
|
def save_image(ctx: ServerContext, output: str, image: Image.Image) -> str:
|
2023-02-02 14:47:37 +00:00
|
|
|
path = base_join(ctx.output_path, output)
|
2023-02-02 14:19:57 +00:00
|
|
|
image.save(path, format=ctx.image_format)
|
2023-02-02 14:31:35 +00:00
|
|
|
logger.debug('saved output image to: %s', path)
|
2023-02-02 04:20:40 +00:00
|
|
|
return path
|
|
|
|
|
|
|
|
|
|
|
|
def save_params(
|
|
|
|
ctx: ServerContext,
|
|
|
|
output: str,
|
|
|
|
params: ImageParams,
|
|
|
|
size: Size,
|
|
|
|
upscale: Optional[UpscaleParams] = None,
|
|
|
|
border: Optional[Border] = None,
|
|
|
|
) -> str:
|
|
|
|
path = base_join(ctx.output_path, '%s.json' % (output))
|
|
|
|
json = json_params(output, params, size, upscale=upscale, border=border)
|
|
|
|
with open(path, 'w') as f:
|
|
|
|
f.write(dumps(json))
|
2023-02-02 14:31:35 +00:00
|
|
|
logger.debug('saved image params to: %s', path)
|
|
|
|
return path
|