UPDATE: Install logic rework
This commit is contained in:
parent
58fe754866
commit
c985baec7b
56
install.py
56
install.py
@ -1,20 +1,37 @@
|
|||||||
import launch
|
import subprocess
|
||||||
import os
|
import os, sys
|
||||||
import pkg_resources
|
import pkg_resources
|
||||||
import sys
|
|
||||||
from tqdm import tqdm
|
from tqdm import tqdm
|
||||||
import urllib.request
|
import urllib.request
|
||||||
|
|
||||||
req_file = os.path.join(os.path.dirname(os.path.realpath(__file__)), "requirements.txt")
|
req_file = os.path.join(os.path.dirname(os.path.realpath(__file__)), "requirements.txt")
|
||||||
|
|
||||||
import os
|
|
||||||
|
|
||||||
models_dir = os.path.abspath("models/roop")
|
models_dir = os.path.abspath("models/roop")
|
||||||
|
|
||||||
model_url = "https://huggingface.co/henryruhs/roop/resolve/main/inswapper_128.onnx"
|
model_url = "https://huggingface.co/henryruhs/roop/resolve/main/inswapper_128.onnx"
|
||||||
model_name = os.path.basename(model_url)
|
model_name = os.path.basename(model_url)
|
||||||
model_path = os.path.join(models_dir, model_name)
|
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):
|
def download(url, path):
|
||||||
request = urllib.request.urlopen(url)
|
request = urllib.request.urlopen(url)
|
||||||
total = int(request.headers.get('Content-Length', 0))
|
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):
|
if not os.path.exists(model_path):
|
||||||
download(model_url, model_path)
|
download(model_url, model_path)
|
||||||
|
|
||||||
|
print("Checking Roop-GE requirements...")
|
||||||
with open(req_file) as file:
|
with open(req_file) as file:
|
||||||
|
install_count = 0
|
||||||
for package in file:
|
for package in file:
|
||||||
|
package_version = None
|
||||||
try:
|
try:
|
||||||
package = package.strip()
|
package = package.strip()
|
||||||
|
|
||||||
if "==" in package:
|
if "==" in package:
|
||||||
package_name, package_version = package.split('==')
|
package_version = package.split('==')[1]
|
||||||
installed_version = pkg_resources.get_distribution(package_name).version
|
if not is_installed(package,package_version):
|
||||||
if installed_version != package_version:
|
install_count += 1
|
||||||
print(
|
run_pip(package)
|
||||||
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}")
|
|
||||||
|
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
print(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
|
raise e
|
||||||
# finally:
|
if install_count > 0:
|
||||||
# print(f'{package} - ok')
|
print(f'\n--- PLEASE, RESTART the Server! ---\n')
|
||||||
|
else:
|
||||||
|
print('Done!')
|
||||||
|
|||||||
@ -3,4 +3,3 @@ onnx==1.14.0
|
|||||||
onnxruntime==1.15.0
|
onnxruntime==1.15.0
|
||||||
opencv-python==4.7.0.72
|
opencv-python==4.7.0.72
|
||||||
diffusers==0.17.1
|
diffusers==0.17.1
|
||||||
tqdm
|
|
||||||
|
|||||||
@ -36,6 +36,6 @@ if not logger.handlers:
|
|||||||
logger.addHandler(handler)
|
logger.addHandler(handler)
|
||||||
|
|
||||||
# Configure logger
|
# 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")
|
loglevel = getattr(logging, loglevel_string.upper(), "info")
|
||||||
logger.setLevel(loglevel)
|
logger.setLevel(loglevel)
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user