stable-diffusion-webui/modules/sysinfo.py

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

216 lines
6.5 KiB
Python
Raw Normal View History

2023-06-03 18:55:35 +08:00
import json
import os
import sys
2024-07-08 15:56:06 +08:00
import subprocess
2023-06-03 18:55:35 +08:00
import platform
import hashlib
import re
2024-07-08 15:56:06 +08:00
from modules import paths_internal, timer, shared, extensions, errors, launch_utils
2023-06-03 18:55:35 +08:00
checksum_token = "DontStealMyGamePlz__WINNERS_DONT_USE_DRUGS__DONT_COPY_THAT_FLOPPY"
environment_whitelist = {
"GIT",
"INDEX_URL",
"WEBUI_LAUNCH_LIVE_OUTPUT",
"GRADIO_ANALYTICS_ENABLED",
"PYTHONPATH",
"TORCH_INDEX_URL",
"TORCH_COMMAND",
"REQS_FILE",
"XFORMERS_PACKAGE",
"CLIP_PACKAGE",
"OPENCLIP_PACKAGE",
"ASSETS_REPO",
"STABLE_DIFFUSION_REPO",
"K_DIFFUSION_REPO",
"BLIP_REPO",
"ASSETS_COMMIT_HASH",
"STABLE_DIFFUSION_COMMIT_HASH",
"K_DIFFUSION_COMMIT_HASH",
"BLIP_COMMIT_HASH",
"COMMANDLINE_ARGS",
"IGNORE_CMD_ARGS_ERRORS",
}
2023-06-03 18:55:35 +08:00
def pretty_bytes(num, suffix="B"):
for unit in ["", "K", "M", "G", "T", "P", "E", "Z", "Y"]:
if abs(num) < 1024 or unit == 'Y':
return f"{num:.0f}{unit}{suffix}"
num /= 1024
def get():
res = get_dict()
text = json.dumps(res, ensure_ascii=False, indent=4)
h = hashlib.sha256(text.encode("utf8"))
text = text.replace(checksum_token, h.hexdigest())
return text
re_checksum = re.compile(r'"Checksum": "([0-9a-fA-F]{64})"')
def check(x):
m = re.search(re_checksum, x)
if not m:
return False
replaced = re.sub(re_checksum, f'"Checksum": "{checksum_token}"', x)
h = hashlib.sha256(replaced.encode("utf8"))
return h.hexdigest() == m.group(1)
2024-07-08 14:45:45 +08:00
def get_cpu_info():
cpu_info = {"model": platform.processor()}
try:
import psutil
cpu_info["count logical"] = psutil.cpu_count(logical=True)
cpu_info["count physical"] = psutil.cpu_count(logical=False)
except Exception as e:
cpu_info["error"] = str(e)
return cpu_info
2023-06-03 18:55:35 +08:00
2024-07-08 14:45:45 +08:00
def get_ram_info():
try:
import psutil
ram = psutil.virtual_memory()
return {x: pretty_bytes(getattr(ram, x, 0)) for x in ["total", "used", "free", "active", "inactive", "buffers", "cached", "shared"] if getattr(ram, x, 0) != 0}
except Exception as e:
return str(e)
2024-07-08 15:33:02 +08:00
def get_packages():
try:
return subprocess.check_output([sys.executable, '-m', 'pip', 'freeze', '--all']).decode("utf8").splitlines()
except Exception as pip_error:
try:
import importlib.metadata
packages = importlib.metadata.distributions()
return sorted([f"{package.metadata['Name']}=={package.version}" for package in packages])
except Exception as e2:
return {'error pip': pip_error, 'error importlib': str(e2)}
2024-07-08 14:45:45 +08:00
def get_dict():
2024-07-08 19:31:50 +08:00
config = get_config()
2023-06-03 18:55:35 +08:00
res = {
"Platform": platform.platform(),
"Python": platform.python_version(),
2024-07-08 15:56:06 +08:00
"Version": launch_utils.git_tag(),
"Commit": launch_utils.commit_hash(),
"Git status": launch_utils.git_status(),
2023-06-03 18:55:35 +08:00
"Script path": paths_internal.script_path,
"Data path": paths_internal.data_path,
"Extensions dir": paths_internal.extensions_dir,
"Checksum": checksum_token,
"Commandline": get_argv(),
2023-06-03 18:55:35 +08:00
"Torch env info": get_torch_sysinfo(),
"Exceptions": errors.get_exceptions(),
2024-07-08 14:45:45 +08:00
"CPU": get_cpu_info(),
"RAM": get_ram_info(),
2024-07-08 19:31:50 +08:00
"Extensions": get_extensions(enabled=True, fallback_disabled_extensions=config.get('disabled_extensions', [])),
"Inactive extensions": get_extensions(enabled=False, fallback_disabled_extensions=config.get('disabled_extensions', [])),
"Environment": get_environment(),
2024-07-08 19:31:50 +08:00
"Config": config,
2023-06-03 18:55:35 +08:00
"Startup": timer.startup_record,
2024-07-08 15:33:02 +08:00
"Packages": get_packages(),
2023-06-03 18:55:35 +08:00
}
return res
def get_environment():
return {k: os.environ[k] for k in sorted(os.environ) if k in environment_whitelist}
def get_argv():
res = []
for v in sys.argv:
if shared.cmd_opts.gradio_auth and shared.cmd_opts.gradio_auth == v:
res.append("<hidden>")
continue
if shared.cmd_opts.api_auth and shared.cmd_opts.api_auth == v:
res.append("<hidden>")
continue
res.append(v)
return res
2024-07-08 14:45:45 +08:00
2023-06-03 18:55:35 +08:00
re_newline = re.compile(r"\r*\n")
def get_torch_sysinfo():
try:
import torch.utils.collect_env
info = torch.utils.collect_env.get_env_info()._asdict()
return {k: re.split(re_newline, str(v)) if "\n" in str(v) else v for k, v in info.items()}
except Exception as e:
return str(e)
2024-07-08 19:31:50 +08:00
def run_git(path, *args):
try:
if os.path.isdir(os.path.join(path, '.git')):
return subprocess.check_output([launch_utils.git, '-C', path, *args], shell=False, encoding='utf8').strip()
return None
except Exception as e:
return str(e)
def get_info_from_repo_path(path):
return {
'name': os.path.basename(path),
'path': path,
2024-07-08 19:33:15 +08:00
'commit': run_git(path, 'rev-parse', 'HEAD'),
2024-07-08 19:31:50 +08:00
'branch': run_git(path, 'branch', '--show-current'),
'remote': run_git(path, 'remote', 'get-url', 'origin')
}
2023-06-03 18:55:35 +08:00
2024-07-08 19:31:50 +08:00
def get_extensions(*, enabled, fallback_disabled_extensions=None):
2023-06-03 18:55:35 +08:00
try:
2024-07-08 19:31:50 +08:00
if extensions.extensions:
def to_json(x: extensions.Extension):
return {
"name": x.name,
"path": x.path,
2024-07-08 19:33:15 +08:00
"commit": x.commit_hash,
2024-07-08 19:31:50 +08:00
"branch": x.branch,
"remote": x.remote,
}
return [to_json(x) for x in extensions.extensions if not x.is_builtin and x.enabled == enabled]
else:
extensions_list = []
for extension_dirname in sorted(os.listdir(paths_internal.extensions_dir)):
path = os.path.join(paths_internal.extensions_dir, extension_dirname)
if enabled == (extension_dirname in fallback_disabled_extensions):
continue
if os.path.isdir(path):
extensions_list.append(get_info_from_repo_path(path))
return extensions_list
2023-06-03 18:55:35 +08:00
except Exception as e:
return str(e)
def get_config():
try:
return shared.opts.data
2024-07-08 18:20:49 +08:00
except Exception as _:
try:
with open(shared.cmd_opts.ui_settings_file, 'r') as f:
return json.load(f)
except Exception as e:
return str(e)