fix(mm): use UUIDv4 for key

This changes the functionality of this PR to only use the updated hashing for model hashes with a UUID for the key.
This commit is contained in:
psychedelicious 2024-03-03 11:08:24 +11:00 committed by Ryan Dick
parent 9f690e0a7f
commit 93aed57e81

View File

@ -20,6 +20,7 @@ from invokeai.app.services.download import DownloadJob, DownloadQueueServiceBase
from invokeai.app.services.events.events_base import EventServiceBase from invokeai.app.services.events.events_base import EventServiceBase
from invokeai.app.services.invoker import Invoker from invokeai.app.services.invoker import Invoker
from invokeai.app.services.model_records import DuplicateModelException, ModelRecordServiceBase from invokeai.app.services.model_records import DuplicateModelException, ModelRecordServiceBase
from invokeai.app.util.misc import uuid_string
from invokeai.backend.model_manager.config import ( from invokeai.backend.model_manager.config import (
AnyModelConfig, AnyModelConfig,
BaseModelType, BaseModelType,
@ -149,7 +150,7 @@ class ModelInstallService(ModelInstallServiceBase):
config = config or {} config = config or {}
if not config.get("source"): if not config.get("source"):
config["source"] = model_path.resolve().as_posix() config["source"] = model_path.resolve().as_posix()
config["key"] = config.get("key", self._create_key()) config["key"] = config.get("key", uuid_string())
info: AnyModelConfig = self._probe_model(Path(model_path), config) info: AnyModelConfig = self._probe_model(Path(model_path), config)
@ -530,7 +531,7 @@ class ModelInstallService(ModelInstallServiceBase):
) -> str: ) -> str:
# Note that we may be passed a pre-populated AnyModelConfig object, # Note that we may be passed a pre-populated AnyModelConfig object,
# in which case the key field should have been populated by the caller (e.g. in `install_path`). # in which case the key field should have been populated by the caller (e.g. in `install_path`).
config["key"] = config.get("key", self._create_key()) config["key"] = config.get("key", uuid_string())
info = info or ModelProbe.probe(model_path, config) info = info or ModelProbe.probe(model_path, config)
override_key: Optional[str] = config.get("key") if config else None override_key: Optional[str] = config.get("key") if config else None