mirror of
https://github.com/ynput/ayon-core.git
synced 2025-12-24 12:54:40 +01:00
204 lines
6.6 KiB
Python
204 lines
6.6 KiB
Python
# -*- coding: utf-8 -*-
|
|
"""Working thread for installer."""
|
|
import os
|
|
import sys
|
|
from pathlib import Path
|
|
|
|
from qtpy import QtCore
|
|
|
|
from .bootstrap_repos import (
|
|
BootstrapRepos,
|
|
OpenPypeVersionInvalid,
|
|
OpenPypeVersionIOError,
|
|
OpenPypeVersionExists,
|
|
OpenPypeVersion
|
|
)
|
|
|
|
from .tools import validate_mongo_connection
|
|
|
|
|
|
class InstallThread(QtCore.QThread):
|
|
"""Install Worker thread.
|
|
|
|
This class takes care of finding OpenPype version on user entered path
|
|
(or loading this path from database). If nothing is entered by user,
|
|
OpenPype will create its zip files from repositories that comes with it.
|
|
|
|
If path contains plain repositories, they are zipped and installed to
|
|
user data dir.
|
|
|
|
"""
|
|
progress = QtCore.Signal(int)
|
|
message = QtCore.Signal((str, bool))
|
|
|
|
def __init__(self, parent=None,):
|
|
self._mongo = None
|
|
self._result = None
|
|
|
|
super().__init__(parent)
|
|
|
|
def result(self):
|
|
"""Result of finished installation."""
|
|
return self._result
|
|
|
|
def _set_result(self, value):
|
|
if self._result is not None:
|
|
raise AssertionError("BUG: Result was set more than once!")
|
|
self._result = value
|
|
|
|
def run(self):
|
|
"""Thread entry point.
|
|
|
|
Using :class:`BootstrapRepos` to either install OpenPype as zip files
|
|
or copy them from location specified by user or retrieved from
|
|
database.
|
|
|
|
"""
|
|
self.message.emit("Installing OpenPype ...", False)
|
|
|
|
# find local version of OpenPype
|
|
bs = BootstrapRepos(
|
|
progress_callback=self.set_progress, message=self.message)
|
|
local_version = OpenPypeVersion.get_installed_version_str()
|
|
|
|
# user did not entered url
|
|
if self._mongo:
|
|
self.message.emit("Saving mongo connection string ...", False)
|
|
bs.secure_registry.set_item("openPypeMongo", self._mongo)
|
|
|
|
elif os.getenv("OPENPYPE_MONGO"):
|
|
self._mongo = os.getenv("OPENPYPE_MONGO")
|
|
else:
|
|
# try to get it from settings registry
|
|
try:
|
|
self._mongo = bs.secure_registry.get_item(
|
|
"openPypeMongo")
|
|
except ValueError:
|
|
self.message.emit(
|
|
"!!! We need MongoDB URL to proceed.", True)
|
|
self._set_result(-1)
|
|
return
|
|
os.environ["OPENPYPE_MONGO"] = self._mongo
|
|
|
|
self.message.emit(
|
|
f"Detecting installed OpenPype versions in {bs.data_dir}",
|
|
False)
|
|
detected = bs.find_openpype(include_zips=True)
|
|
if not detected and getattr(sys, 'frozen', False):
|
|
self.message.emit("None detected.", True)
|
|
self.message.emit(("We will use OpenPype coming with "
|
|
"installer."), False)
|
|
openpype_version = bs.create_version_from_frozen_code()
|
|
if not openpype_version:
|
|
self.message.emit(
|
|
f"!!! Install failed - {openpype_version}", True)
|
|
self._set_result(-1)
|
|
return
|
|
self.message.emit(f"Using: {openpype_version}", False)
|
|
bs.install_version(openpype_version)
|
|
self.message.emit(f"Installed as {openpype_version}", False)
|
|
self.progress.emit(100)
|
|
self._set_result(1)
|
|
return
|
|
|
|
if detected and not OpenPypeVersion.get_installed_version().is_compatible(detected[-1]): # noqa: E501
|
|
self.message.emit((
|
|
f"Latest detected version {detected[-1]} "
|
|
"is not compatible with the currently running "
|
|
f"{local_version}"
|
|
), True)
|
|
self.message.emit((
|
|
"Filtering detected versions to compatible ones..."
|
|
), False)
|
|
|
|
# filter results to get only compatible versions
|
|
detected = [
|
|
version for version in detected
|
|
if version.is_compatible(
|
|
OpenPypeVersion.get_installed_version())
|
|
]
|
|
|
|
if detected:
|
|
if OpenPypeVersion(
|
|
version=local_version, path=Path()) < detected[-1]:
|
|
self.message.emit((
|
|
f"Latest installed version {detected[-1]} is newer "
|
|
f"then currently running {local_version}"
|
|
), False)
|
|
self.message.emit("Skipping OpenPype install ...", False)
|
|
if detected[-1].path.suffix.lower() == ".zip":
|
|
bs.extract_openpype(detected[-1])
|
|
self._set_result(0)
|
|
return
|
|
|
|
if OpenPypeVersion(version=local_version).get_main_version() == detected[-1].get_main_version(): # noqa: E501
|
|
self.message.emit((
|
|
f"Latest installed version is the same as "
|
|
f"currently running {local_version}"
|
|
), False)
|
|
self.message.emit("Skipping OpenPype install ...", False)
|
|
self._set_result(0)
|
|
return
|
|
|
|
self.message.emit((
|
|
"All installed versions are older then "
|
|
f"currently running one {local_version}"
|
|
), False)
|
|
|
|
self.message.emit("None detected.", False)
|
|
|
|
self.message.emit(
|
|
f"We will use local OpenPype version {local_version}", False)
|
|
|
|
local_openpype = bs.create_version_from_live_code()
|
|
if not local_openpype:
|
|
self.message.emit(
|
|
f"!!! Install failed - {local_openpype}", True)
|
|
self._set_result(-1)
|
|
return
|
|
|
|
try:
|
|
bs.install_version(local_openpype)
|
|
except (OpenPypeVersionExists,
|
|
OpenPypeVersionInvalid,
|
|
OpenPypeVersionIOError) as e:
|
|
self.message.emit(f"Installed failed: ", True)
|
|
self.message.emit(str(e), True)
|
|
self._set_result(-1)
|
|
return
|
|
|
|
self.message.emit(f"Installed as {local_openpype}", False)
|
|
self.progress.emit(100)
|
|
self._set_result(1)
|
|
return
|
|
|
|
self.progress.emit(100)
|
|
self._set_result(1)
|
|
return
|
|
|
|
def set_path(self, path: str) -> None:
|
|
"""Helper to set path.
|
|
|
|
Args:
|
|
path (str): Path to set.
|
|
|
|
"""
|
|
self._path = path
|
|
|
|
def set_mongo(self, mongo: str) -> None:
|
|
"""Helper to set mongo url.
|
|
|
|
Args:
|
|
mongo (str): Mongodb url.
|
|
|
|
"""
|
|
self._mongo = mongo
|
|
|
|
def set_progress(self, progress: int) -> None:
|
|
"""Helper to set progress bar.
|
|
|
|
Args:
|
|
progress (int): Progress in percents.
|
|
|
|
"""
|
|
self.progress.emit(progress)
|