UPDATE: Install logic rework

This commit is contained in:
Gourieff 2023-07-19 02:13:40 +07:00
parent 58fe754866
commit c985baec7b
3 changed files with 35 additions and 24 deletions

View File

@ -1,20 +1,37 @@
import launch
import os
import subprocess
import os, sys
import pkg_resources
import sys
from tqdm import tqdm
import urllib.request
req_file = os.path.join(os.path.dirname(os.path.realpath(__file__)), "requirements.txt")
import os
models_dir = os.path.abspath("models/roop")
model_url = "https://huggingface.co/henryruhs/roop/resolve/main/inswapper_128.onnx"
model_name = os.path.basename(model_url)
model_path = os.path.join(models_dir, model_name)
def run_pip(*args):
subprocess.run([sys.executable, "-m", "pip", "install", *args])
def is_installed (
package: str, version: str | None = None
):
has_package = None
try:
has_package = pkg_resources.get_distribution(package)
if has_package is not None:
installed_version = has_package.version
if installed_version != version:
return False
else:
return True
else:
return False
except:
return False
def download(url, path):
request = urllib.request.urlopen(url)
total = int(request.headers.get('Content-Length', 0))
@ -27,28 +44,23 @@ if not os.path.exists(models_dir):
if not os.path.exists(model_path):
download(model_url, model_path)
print("Checking Roop-GE requirements...")
with open(req_file) as file:
install_count = 0
for package in file:
package_version = None
try:
package = package.strip()
if "==" in package:
package_name, package_version = package.split('==')
installed_version = pkg_resources.get_distribution(package_name).version
if installed_version != package_version:
print(
f"Running install of {package}, {installed_version} vs {package_version}"
)
launch.run_pip(
f"install {package}",
f"sd-webui-roop-nsfw requirement: changing {package_name} version from {installed_version} to {package_version}"
)
elif not launch.is_installed(package):
launch.run_pip(f"install {package}", f"sd-webui-roop-nsfw requirement: {package}")
package_version = package.split('==')[1]
if not is_installed(package,package_version):
install_count += 1
run_pip(package)
except Exception as e:
print(e)
print(f"Warning: Failed to install {package}, nsfw-roop will not work.")
print(f"Warning: Failed to install {package}, Roop-GE will not work.")
raise e
# finally:
# print(f'{package} - ok')
if install_count > 0:
print(f'\n--- PLEASE, RESTART the Server! ---\n')
else:
print('Done!')

View File

@ -3,4 +3,3 @@ onnx==1.14.0
onnxruntime==1.15.0
opencv-python==4.7.0.72
diffusers==0.17.1
tqdm

View File

@ -36,6 +36,6 @@ if not logger.handlers:
logger.addHandler(handler)
# Configure logger
loglevel_string = getattr(shared.cmd_opts, "controlnet_loglevel", "INFO")
loglevel_string = getattr(shared.cmd_opts, "roop_loglevel", "INFO")
loglevel = getattr(logging, loglevel_string.upper(), "info")
logger.setLevel(loglevel)