import json import os import sys import traceback import platform import hashlib import pkg_resources import psutil import re import launch from modules import paths_internal, timer checksum_token = "DontStealMyGamePlz__WINNERS_DONT_USE_DRUGS__DONT_COPY_THAT_FLOPPY" 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) def get_dict(): ram = psutil.virtual_memory() res = { "Platform": platform.platform(), "Python": platform.python_version(), "Version": launch.git_tag(), "Commit": launch.commit_hash(), "Script path": paths_internal.script_path, "Data path": paths_internal.data_path, "Extensions dir": paths_internal.extensions_dir, "Checksum": checksum_token, "Commandline": sys.argv, "Torch env info": get_torch_sysinfo(), "Exceptions": get_exceptions(), "CPU": { "model": platform.processor(), "count logical": psutil.cpu_count(logical=True), "count physical": psutil.cpu_count(logical=False), }, "RAM": { x: pretty_bytes(getattr(ram, x, 0)) for x in ["total", "used", "free", "active", "inactive", "buffers", "cached", "shared"] if getattr(ram, x, 0) != 0 }, "Extensions": get_extensions(enabled=True), "Inactive extensions": get_extensions(enabled=False), "Environment": {k: os.environ[k] for k in sorted(os.environ)}, "Config": get_config(), "Startup": timer.startup_record, "Packages": sorted([f"{pkg.key}=={pkg.version}" for pkg in pkg_resources.working_set]), } return res def format_traceback(tb): return [[f"{x.filename}, line {x.lineno}, {x.name}", x.line] for x in traceback.extract_tb(tb)] def get_exceptions(): try: from modules import errors return [{"exception": str(e), "traceback": format_traceback(tb)} for e, tb in reversed(errors.exception_records)] except Exception as e: return str(e) 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) def get_extensions(*, enabled): try: from modules import extensions def to_json(x: extensions.Extension): return { "name": x.name, "path": x.path, "version": x.version, "branch": x.branch, "remote": x.remote, } return [to_json(x) for x in extensions.extensions if not x.is_builtin and x.enabled == enabled] except Exception as e: return str(e) def get_config(): try: from modules import shared return shared.opts.data except Exception as e: return str(e)