Compare commits
57 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
982a60e85f | ||
|
|
9d5faa096c | ||
|
|
97d0dc20f1 | ||
|
|
8d99ff07b6 | ||
|
|
04fa540a8c | ||
|
|
eb41867e04 | ||
|
|
eee5d7d9e8 | ||
|
|
e983f9ed35 | ||
|
|
8b16ef641b | ||
|
|
e87d616b7a | ||
|
|
2220f325fc | ||
|
|
b53ed47ccb | ||
|
|
39df2743fe | ||
|
|
3f729aaf03 | ||
|
|
b7324621e4 | ||
|
|
e8c782c8e1 | ||
|
|
9136505565 | ||
|
|
f406d728cc | ||
|
|
d649ca47c6 | ||
|
|
e8111527b4 | ||
|
|
2af66d7efc | ||
|
|
27706f37f6 | ||
|
|
3de17b2fa6 | ||
|
|
22ecb5de95 | ||
|
|
992b8b3cb5 | ||
|
|
bebc16d5a6 | ||
|
|
ddb719f866 | ||
|
|
0bd1bf2605 | ||
|
|
fd32ba4035 | ||
|
|
22f723b920 | ||
|
|
1248bd0413 | ||
|
|
c150eec2b6 | ||
|
|
c7248c2d47 | ||
|
|
e71e68e298 | ||
|
|
6969557693 | ||
|
|
f6be5ad839 | ||
|
|
cebe3664fd | ||
|
|
cdab465c90 | ||
|
|
144384655c | ||
|
|
0e213d6dab | ||
|
|
21294a4e4a | ||
|
|
3ba4d44d9e | ||
|
|
1f86ef5a37 | ||
|
|
fac60da333 | ||
|
|
5a5a37dfee | ||
|
|
0d487bc14f | ||
|
|
a52b4eb5ed | ||
|
|
f1b7f5f52f | ||
|
|
5ef58652bf | ||
|
|
e26a9e75c6 | ||
|
|
b0035ff4a7 | ||
|
|
94b6f9b2fe | ||
|
|
cad1482b3f | ||
|
|
ea7aafb3e6 | ||
|
|
42b15ad4a5 | ||
|
|
d3d613cca9 | ||
|
|
86893d999a |
@@ -150,6 +150,7 @@ In `ComfyUI-Manager` V3.0 and later, configuration files and dynamically generat
|
|||||||
* Configurable channel lists: `<USER_DIRECTORY>/default/ComfyUI-Manager/channels.ini`
|
* Configurable channel lists: `<USER_DIRECTORY>/default/ComfyUI-Manager/channels.ini`
|
||||||
* Configurable pip overrides: `<USER_DIRECTORY>/default/ComfyUI-Manager/pip_overrides.json`
|
* Configurable pip overrides: `<USER_DIRECTORY>/default/ComfyUI-Manager/pip_overrides.json`
|
||||||
* Configurable pip blacklist: `<USER_DIRECTORY>/default/ComfyUI-Manager/pip_blacklist.list`
|
* Configurable pip blacklist: `<USER_DIRECTORY>/default/ComfyUI-Manager/pip_blacklist.list`
|
||||||
|
* Configurable pip auto fix: `<USER_DIRECTORY>/default/ComfyUI-Manager/pip_auto_fix.list`
|
||||||
* Saved snapshot files: `<USER_DIRECTORY>/default/ComfyUI-Manager/snapshots`
|
* Saved snapshot files: `<USER_DIRECTORY>/default/ComfyUI-Manager/snapshots`
|
||||||
* Startup script files: `<USER_DIRECTORY>/default/ComfyUI-Manager/startup-scripts`
|
* Startup script files: `<USER_DIRECTORY>/default/ComfyUI-Manager/startup-scripts`
|
||||||
* Component files: `<USER_DIRECTORY>/default/ComfyUI-Manager/components`
|
* Component files: `<USER_DIRECTORY>/default/ComfyUI-Manager/components`
|
||||||
@@ -306,6 +307,10 @@ The following settings are applied based on the section marked as `is_default`.
|
|||||||
* Prevent the installation of specific pip packages
|
* Prevent the installation of specific pip packages
|
||||||
* List the package names one per line in the `pip_blacklist.list` file.
|
* List the package names one per line in the `pip_blacklist.list` file.
|
||||||
|
|
||||||
|
* Automatically Restoring pip Installation
|
||||||
|
* If you list pip spec requirements in `pip_auto_fix.list`, similar to `requirements.txt`, it will automatically restore the specified versions when starting ComfyUI or when versions get mismatched during various custom node installations.
|
||||||
|
* `--index-url` can be used.
|
||||||
|
|
||||||
* Use `aria2` as downloader
|
* Use `aria2` as downloader
|
||||||
* [howto](docs/en/use_aria2.md)
|
* [howto](docs/en/use_aria2.md)
|
||||||
|
|
||||||
|
|||||||
@@ -7,7 +7,10 @@ if not os.path.exists(cli_mode_flag):
|
|||||||
sys.path.append(os.path.join(os.path.dirname(__file__), "glob"))
|
sys.path.append(os.path.join(os.path.dirname(__file__), "glob"))
|
||||||
import manager_server # noqa: F401
|
import manager_server # noqa: F401
|
||||||
import share_3rdparty # noqa: F401
|
import share_3rdparty # noqa: F401
|
||||||
WEB_DIRECTORY = "js"
|
import cm_global
|
||||||
|
|
||||||
|
if not cm_global.disable_front and not 'DISABLE_COMFYUI_MANAGER_FRONT' in os.environ:
|
||||||
|
WEB_DIRECTORY = "js"
|
||||||
else:
|
else:
|
||||||
print("\n[ComfyUI-Manager] !! cli-only-mode is enabled !!\n")
|
print("\n[ComfyUI-Manager] !! cli-only-mode is enabled !!\n")
|
||||||
|
|
||||||
|
|||||||
53
cm-cli.py
53
cm-cli.py
@@ -61,13 +61,17 @@ if os.path.exists(os.path.join(manager_util.comfyui_manager_path, "pip_blacklist
|
|||||||
|
|
||||||
|
|
||||||
def check_comfyui_hash():
|
def check_comfyui_hash():
|
||||||
repo = git.Repo(comfy_path)
|
try:
|
||||||
core.comfy_ui_revision = len(list(repo.iter_commits('HEAD')))
|
repo = git.Repo(comfy_path)
|
||||||
|
core.comfy_ui_revision = len(list(repo.iter_commits('HEAD')))
|
||||||
|
core.comfy_ui_commit_datetime = repo.head.commit.committed_datetime
|
||||||
|
except:
|
||||||
|
print('[bold yellow]INFO: Frozen ComfyUI mode.[/bold yellow]')
|
||||||
|
core.comfy_ui_revision = 0
|
||||||
|
core.comfy_ui_commit_datetime = 0
|
||||||
|
|
||||||
cm_global.variables['comfyui.revision'] = core.comfy_ui_revision
|
cm_global.variables['comfyui.revision'] = core.comfy_ui_revision
|
||||||
|
|
||||||
core.comfy_ui_commit_datetime = repo.head.commit.committed_datetime
|
|
||||||
|
|
||||||
|
|
||||||
check_comfyui_hash() # This is a preparation step for manager_core
|
check_comfyui_hash() # This is a preparation step for manager_core
|
||||||
core.check_invalid_nodes()
|
core.check_invalid_nodes()
|
||||||
@@ -152,6 +156,11 @@ class Ctx:
|
|||||||
if y != '':
|
if y != '':
|
||||||
cm_global.pip_blacklist.add(y)
|
cm_global.pip_blacklist.add(y)
|
||||||
|
|
||||||
|
def update_custom_nodes_dir(self, target_dir):
|
||||||
|
import folder_paths
|
||||||
|
a, b = folder_paths.folder_names_and_paths['custom_nodes']
|
||||||
|
folder_paths.folder_names_and_paths['custom_nodes'] = [os.path.abspath(target_dir)], set()
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def get_startup_scripts_path():
|
def get_startup_scripts_path():
|
||||||
return os.path.join(core.manager_startup_script_path, "install-scripts.txt")
|
return os.path.join(core.manager_startup_script_path, "install-scripts.txt")
|
||||||
@@ -245,7 +254,7 @@ def fix_node(node_spec_str, is_all=False, cnt_msg=''):
|
|||||||
res = unified_manager.unified_fix(node_name, version_spec, no_deps=cmd_ctx.no_deps)
|
res = unified_manager.unified_fix(node_name, version_spec, no_deps=cmd_ctx.no_deps)
|
||||||
|
|
||||||
if not res.result:
|
if not res.result:
|
||||||
print(f"ERROR: f{res.msg}")
|
print(f"[bold red]ERROR: f{res.msg}[/bold red]")
|
||||||
|
|
||||||
|
|
||||||
def uninstall_node(node_spec_str: str, is_all: bool = False, cnt_msg: str = ''):
|
def uninstall_node(node_spec_str: str, is_all: bool = False, cnt_msg: str = ''):
|
||||||
@@ -638,7 +647,7 @@ def install(
|
|||||||
cmd_ctx.set_channel_mode(channel, mode)
|
cmd_ctx.set_channel_mode(channel, mode)
|
||||||
cmd_ctx.set_no_deps(no_deps)
|
cmd_ctx.set_no_deps(no_deps)
|
||||||
|
|
||||||
pip_fixer = manager_util.PIPFixer(manager_util.get_installed_packages())
|
pip_fixer = manager_util.PIPFixer(manager_util.get_installed_packages(), comfy_path, core.manager_files_path)
|
||||||
for_each_nodes(nodes, act=install_node)
|
for_each_nodes(nodes, act=install_node)
|
||||||
pip_fixer.fix_broken()
|
pip_fixer.fix_broken()
|
||||||
|
|
||||||
@@ -676,7 +685,7 @@ def reinstall(
|
|||||||
cmd_ctx.set_channel_mode(channel, mode)
|
cmd_ctx.set_channel_mode(channel, mode)
|
||||||
cmd_ctx.set_no_deps(no_deps)
|
cmd_ctx.set_no_deps(no_deps)
|
||||||
|
|
||||||
pip_fixer = manager_util.PIPFixer(manager_util.get_installed_packages())
|
pip_fixer = manager_util.PIPFixer(manager_util.get_installed_packages(), comfy_path, core.manager_files_path)
|
||||||
for_each_nodes(nodes, act=reinstall_node)
|
for_each_nodes(nodes, act=reinstall_node)
|
||||||
pip_fixer.fix_broken()
|
pip_fixer.fix_broken()
|
||||||
|
|
||||||
@@ -702,7 +711,7 @@ def uninstall(
|
|||||||
for_each_nodes(nodes, act=uninstall_node)
|
for_each_nodes(nodes, act=uninstall_node)
|
||||||
|
|
||||||
|
|
||||||
@app.command(help="Disable custom nodes")
|
@app.command(help="Update custom nodes")
|
||||||
def update(
|
def update(
|
||||||
nodes: List[str] = typer.Argument(
|
nodes: List[str] = typer.Argument(
|
||||||
...,
|
...,
|
||||||
@@ -730,7 +739,7 @@ def update(
|
|||||||
if 'all' in nodes:
|
if 'all' in nodes:
|
||||||
asyncio.run(auto_save_snapshot())
|
asyncio.run(auto_save_snapshot())
|
||||||
|
|
||||||
pip_fixer = manager_util.PIPFixer(manager_util.get_installed_packages())
|
pip_fixer = manager_util.PIPFixer(manager_util.get_installed_packages(), comfy_path, core.manager_files_path)
|
||||||
|
|
||||||
for x in nodes:
|
for x in nodes:
|
||||||
if x.lower() in ['comfyui', 'comfy', 'all']:
|
if x.lower() in ['comfyui', 'comfy', 'all']:
|
||||||
@@ -831,7 +840,7 @@ def fix(
|
|||||||
if 'all' in nodes:
|
if 'all' in nodes:
|
||||||
asyncio.run(auto_save_snapshot())
|
asyncio.run(auto_save_snapshot())
|
||||||
|
|
||||||
pip_fixer = manager_util.PIPFixer(manager_util.get_installed_packages())
|
pip_fixer = manager_util.PIPFixer(manager_util.get_installed_packages(), comfy_path, core.manager_files_path)
|
||||||
for_each_nodes(nodes, fix_node, allow_all=True)
|
for_each_nodes(nodes, fix_node, allow_all=True)
|
||||||
pip_fixer.fix_broken()
|
pip_fixer.fix_broken()
|
||||||
|
|
||||||
@@ -1038,13 +1047,17 @@ def save_snapshot(
|
|||||||
):
|
):
|
||||||
cmd_ctx.set_user_directory(user_directory)
|
cmd_ctx.set_user_directory(user_directory)
|
||||||
|
|
||||||
|
if output is None:
|
||||||
|
print("[bold red]ERROR: missing output path[/bold red]")
|
||||||
|
raise typer.Exit(code=1)
|
||||||
|
|
||||||
if(not output.endswith('.json') and not output.endswith('.yaml')):
|
if(not output.endswith('.json') and not output.endswith('.yaml')):
|
||||||
print("ERROR: output path should be either '.json' or '.yaml' file.")
|
print("[bold red]ERROR: output path should be either '.json' or '.yaml' file.[/bold red]")
|
||||||
raise typer.Exit(code=1)
|
raise typer.Exit(code=1)
|
||||||
|
|
||||||
dir_path = os.path.dirname(output)
|
dir_path = os.path.dirname(output)
|
||||||
if(dir_path != '' and not os.path.exists(dir_path)):
|
if(dir_path != '' and not os.path.exists(dir_path)):
|
||||||
print(f"ERROR: {output} path not exists.")
|
print(f"[bold red]ERROR: {output} path not exists.[/bold red]")
|
||||||
raise typer.Exit(code=1)
|
raise typer.Exit(code=1)
|
||||||
|
|
||||||
path = asyncio.run(core.save_snapshot_with_postfix('snapshot', output, not full_snapshot))
|
path = asyncio.run(core.save_snapshot_with_postfix('snapshot', output, not full_snapshot))
|
||||||
@@ -1075,10 +1088,17 @@ def restore_snapshot(
|
|||||||
user_directory: str = typer.Option(
|
user_directory: str = typer.Option(
|
||||||
None,
|
None,
|
||||||
help="user directory"
|
help="user directory"
|
||||||
|
),
|
||||||
|
restore_to: Optional[str] = typer.Option(
|
||||||
|
None,
|
||||||
|
help="Manually specify the installation path for the custom node. Ignore user directory."
|
||||||
)
|
)
|
||||||
):
|
):
|
||||||
cmd_ctx.set_user_directory(user_directory)
|
cmd_ctx.set_user_directory(user_directory)
|
||||||
|
|
||||||
|
if restore_to:
|
||||||
|
cmd_ctx.update_custom_nodes_dir(restore_to)
|
||||||
|
|
||||||
extras = []
|
extras = []
|
||||||
if pip_non_url:
|
if pip_non_url:
|
||||||
extras.append('--pip-non-url')
|
extras.append('--pip-non-url')
|
||||||
@@ -1099,7 +1119,7 @@ def restore_snapshot(
|
|||||||
print(f"[bold red]ERROR: `{snapshot_path}` is not exists.[/bold red]")
|
print(f"[bold red]ERROR: `{snapshot_path}` is not exists.[/bold red]")
|
||||||
exit(1)
|
exit(1)
|
||||||
|
|
||||||
pip_fixer = manager_util.PIPFixer(manager_util.get_installed_packages())
|
pip_fixer = manager_util.PIPFixer(manager_util.get_installed_packages(), comfy_path, core.manager_files_path)
|
||||||
try:
|
try:
|
||||||
asyncio.run(core.restore_snapshot(snapshot_path, extras))
|
asyncio.run(core.restore_snapshot(snapshot_path, extras))
|
||||||
except Exception:
|
except Exception:
|
||||||
@@ -1131,7 +1151,7 @@ def restore_dependencies(
|
|||||||
total = len(node_paths)
|
total = len(node_paths)
|
||||||
i = 1
|
i = 1
|
||||||
|
|
||||||
pip_fixer = manager_util.PIPFixer(manager_util.get_installed_packages())
|
pip_fixer = manager_util.PIPFixer(manager_util.get_installed_packages(), comfy_path, core.manager_files_path)
|
||||||
for x in node_paths:
|
for x in node_paths:
|
||||||
print("----------------------------------------------------------------------------------------------------")
|
print("----------------------------------------------------------------------------------------------------")
|
||||||
print(f"Restoring [{i}/{total}]: {x}")
|
print(f"Restoring [{i}/{total}]: {x}")
|
||||||
@@ -1150,7 +1170,7 @@ def post_install(
|
|||||||
):
|
):
|
||||||
path = os.path.expanduser(path)
|
path = os.path.expanduser(path)
|
||||||
|
|
||||||
pip_fixer = manager_util.PIPFixer(manager_util.get_installed_packages())
|
pip_fixer = manager_util.PIPFixer(manager_util.get_installed_packages(), comfy_path, core.manager_files_path)
|
||||||
unified_manager.execute_install_script('', path, instant_execution=True)
|
unified_manager.execute_install_script('', path, instant_execution=True)
|
||||||
pip_fixer.fix_broken()
|
pip_fixer.fix_broken()
|
||||||
|
|
||||||
@@ -1194,8 +1214,7 @@ def install_deps(
|
|||||||
print(f"[bold red]Invalid json file: {deps}[/bold red]")
|
print(f"[bold red]Invalid json file: {deps}[/bold red]")
|
||||||
exit(1)
|
exit(1)
|
||||||
|
|
||||||
|
pip_fixer = manager_util.PIPFixer(manager_util.get_installed_packages(), comfy_path, core.manager_files_path)
|
||||||
pip_fixer = manager_util.PIPFixer(manager_util.get_installed_packages())
|
|
||||||
for k in json_obj['custom_nodes'].keys():
|
for k in json_obj['custom_nodes'].keys():
|
||||||
state = core.simple_check_custom_node(k)
|
state = core.simple_check_custom_node(k)
|
||||||
if state == 'installed':
|
if state == 'installed':
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -122,7 +122,8 @@ ComfyUI-Loopchain
|
|||||||
* `--pip-non-url`: Restore for pip packages registered on PyPI.
|
* `--pip-non-url`: Restore for pip packages registered on PyPI.
|
||||||
* `--pip-non-local-url`: Restore for pip packages registered at web URLs.
|
* `--pip-non-local-url`: Restore for pip packages registered at web URLs.
|
||||||
* `--pip-local-url`: Restore for pip packages specified by local paths.
|
* `--pip-local-url`: Restore for pip packages specified by local paths.
|
||||||
|
* `--user-directory`: Set the user directory.
|
||||||
|
* `--restore-to`: The path where the restored custom nodes will be installed. (When this option is applied, only the custom nodes installed in the target path are recognized as installed.)
|
||||||
|
|
||||||
### 5. CLI Only Mode
|
### 5. CLI Only Mode
|
||||||
|
|
||||||
|
|||||||
@@ -123,7 +123,8 @@ ComfyUI-Loopchain
|
|||||||
* `--pip-non-url`: PyPI 에 등록된 pip 패키지들에 대해서 복구를 수행
|
* `--pip-non-url`: PyPI 에 등록된 pip 패키지들에 대해서 복구를 수행
|
||||||
* `--pip-non-local-url`: web URL에 등록된 pip 패키지들에 대해서 복구를 수행
|
* `--pip-non-local-url`: web URL에 등록된 pip 패키지들에 대해서 복구를 수행
|
||||||
* `--pip-local-url`: local 경로를 지정하고 있는 pip 패키지들에 대해서 복구를 수행
|
* `--pip-local-url`: local 경로를 지정하고 있는 pip 패키지들에 대해서 복구를 수행
|
||||||
|
* `--user-directory`: 사용자 디렉토리 설정
|
||||||
|
* `--restore-to`: 복구될 커스텀 노드가 설치될 경로. (이 옵션을 적용할 경우 오직 대상 경로에 설치된 custom nodes 만 설치된 것으로 인식함.)
|
||||||
|
|
||||||
### 5. CLI only mode
|
### 5. CLI only mode
|
||||||
|
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
6339
github-stats.json
6339
github-stats.json
File diff suppressed because it is too large
Load Diff
@@ -113,3 +113,5 @@ def add_on_revision_detected(k, f):
|
|||||||
|
|
||||||
|
|
||||||
error_dict = {}
|
error_dict = {}
|
||||||
|
|
||||||
|
disable_front = False
|
||||||
@@ -1,12 +1,15 @@
|
|||||||
import requests
|
|
||||||
from dataclasses import dataclass
|
|
||||||
from typing import List
|
|
||||||
import manager_util
|
|
||||||
import toml
|
|
||||||
import os
|
|
||||||
import asyncio
|
import asyncio
|
||||||
import json
|
import json
|
||||||
|
import os
|
||||||
|
import platform
|
||||||
import time
|
import time
|
||||||
|
from dataclasses import dataclass
|
||||||
|
from typing import List
|
||||||
|
|
||||||
|
import manager_core
|
||||||
|
import manager_util
|
||||||
|
import requests
|
||||||
|
import toml
|
||||||
|
|
||||||
base_url = "https://api.comfy.org"
|
base_url = "https://api.comfy.org"
|
||||||
|
|
||||||
@@ -32,9 +35,43 @@ async def _get_cnr_data(cache_mode=True, dont_wait=True):
|
|||||||
page = 1
|
page = 1
|
||||||
|
|
||||||
full_nodes = {}
|
full_nodes = {}
|
||||||
|
|
||||||
|
|
||||||
|
# Determine form factor based on environment and platform
|
||||||
|
is_desktop = bool(os.environ.get('__COMFYUI_DESKTOP_VERSION__'))
|
||||||
|
system = platform.system().lower()
|
||||||
|
is_windows = system == 'windows'
|
||||||
|
is_mac = system == 'darwin'
|
||||||
|
is_linux = system == 'linux'
|
||||||
|
|
||||||
|
# Get ComfyUI version tag
|
||||||
|
if is_desktop:
|
||||||
|
# extract version from pyproject.toml instead of git tag
|
||||||
|
comfyui_ver = manager_core.get_current_comfyui_ver() or 'unknown'
|
||||||
|
else:
|
||||||
|
comfyui_ver = manager_core.get_comfyui_tag() or 'unknown'
|
||||||
|
|
||||||
|
if is_desktop:
|
||||||
|
if is_windows:
|
||||||
|
form_factor = 'desktop-win'
|
||||||
|
elif is_mac:
|
||||||
|
form_factor = 'desktop-mac'
|
||||||
|
else:
|
||||||
|
form_factor = 'other'
|
||||||
|
else:
|
||||||
|
if is_windows:
|
||||||
|
form_factor = 'git-windows'
|
||||||
|
elif is_mac:
|
||||||
|
form_factor = 'git-mac'
|
||||||
|
elif is_linux:
|
||||||
|
form_factor = 'git-linux'
|
||||||
|
else:
|
||||||
|
form_factor = 'other'
|
||||||
|
|
||||||
while remained:
|
while remained:
|
||||||
sub_uri = f'{base_url}/nodes?page={page}&limit=30'
|
# Add comfyui_version and form_factor to the API request
|
||||||
sub_json_obj = await asyncio.wait_for(manager_util.get_data_with_cache(sub_uri, cache_mode=False, silent=True), timeout=30)
|
sub_uri = f'{base_url}/nodes?page={page}&limit=30&comfyui_version={comfyui_ver}&form_factor={form_factor}'
|
||||||
|
sub_json_obj = await asyncio.wait_for(manager_util.get_data_with_cache(sub_uri, cache_mode=False, silent=True, dont_cache=True), timeout=30)
|
||||||
remained = page < sub_json_obj['totalPages']
|
remained = page < sub_json_obj['totalPages']
|
||||||
|
|
||||||
for x in sub_json_obj['nodes']:
|
for x in sub_json_obj['nodes']:
|
||||||
|
|||||||
@@ -23,6 +23,7 @@ import yaml
|
|||||||
import zipfile
|
import zipfile
|
||||||
import traceback
|
import traceback
|
||||||
from concurrent.futures import ThreadPoolExecutor, as_completed
|
from concurrent.futures import ThreadPoolExecutor, as_completed
|
||||||
|
import toml
|
||||||
|
|
||||||
orig_print = print
|
orig_print = print
|
||||||
|
|
||||||
@@ -42,7 +43,7 @@ import manager_downloader
|
|||||||
from node_package import InstalledNodePackage
|
from node_package import InstalledNodePackage
|
||||||
|
|
||||||
|
|
||||||
version_code = [3, 26]
|
version_code = [3, 30, 3]
|
||||||
version_str = f"V{version_code[0]}.{version_code[1]}" + (f'.{version_code[2]}' if len(version_code) > 2 else '')
|
version_str = f"V{version_code[0]}.{version_code[1]}" + (f'.{version_code[2]}' if len(version_code) > 2 else '')
|
||||||
|
|
||||||
|
|
||||||
@@ -74,13 +75,31 @@ def get_custom_nodes_paths():
|
|||||||
|
|
||||||
|
|
||||||
def get_comfyui_tag():
|
def get_comfyui_tag():
|
||||||
repo = git.Repo(comfy_path)
|
|
||||||
try:
|
try:
|
||||||
|
repo = git.Repo(comfy_path)
|
||||||
return repo.git.describe('--tags')
|
return repo.git.describe('--tags')
|
||||||
except:
|
except:
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
|
||||||
|
def get_current_comfyui_ver():
|
||||||
|
"""
|
||||||
|
Extract version from pyproject.toml
|
||||||
|
"""
|
||||||
|
toml_path = os.path.join(comfy_path, 'pyproject.toml')
|
||||||
|
if not os.path.exists(toml_path):
|
||||||
|
return None
|
||||||
|
else:
|
||||||
|
try:
|
||||||
|
with open(toml_path, "r", encoding="utf-8") as f:
|
||||||
|
data = toml.load(f)
|
||||||
|
|
||||||
|
project = data.get('project', {})
|
||||||
|
return project.get('version')
|
||||||
|
except:
|
||||||
|
return None
|
||||||
|
|
||||||
|
|
||||||
def get_script_env():
|
def get_script_env():
|
||||||
new_env = os.environ.copy()
|
new_env = os.environ.copy()
|
||||||
git_exe = get_config().get('git_exe')
|
git_exe = get_config().get('git_exe')
|
||||||
@@ -154,7 +173,7 @@ def check_invalid_nodes():
|
|||||||
|
|
||||||
|
|
||||||
# read env vars
|
# read env vars
|
||||||
comfy_path = os.environ.get('COMFYUI_PATH')
|
comfy_path: str = os.environ.get('COMFYUI_PATH')
|
||||||
comfy_base_path = os.environ.get('COMFYUI_FOLDERS_BASE_PATH')
|
comfy_base_path = os.environ.get('COMFYUI_FOLDERS_BASE_PATH')
|
||||||
|
|
||||||
if comfy_path is None:
|
if comfy_path is None:
|
||||||
@@ -828,7 +847,7 @@ class UnifiedManager:
|
|||||||
else:
|
else:
|
||||||
if os.path.exists(requirements_path) and not no_deps:
|
if os.path.exists(requirements_path) and not no_deps:
|
||||||
print("Install: pip packages")
|
print("Install: pip packages")
|
||||||
pip_fixer = manager_util.PIPFixer(manager_util.get_installed_packages())
|
pip_fixer = manager_util.PIPFixer(manager_util.get_installed_packages(), comfy_path, manager_files_path)
|
||||||
res = True
|
res = True
|
||||||
lines = manager_util.robust_readlines(requirements_path)
|
lines = manager_util.robust_readlines(requirements_path)
|
||||||
for line in lines:
|
for line in lines:
|
||||||
@@ -997,7 +1016,7 @@ class UnifiedManager:
|
|||||||
|
|
||||||
return result
|
return result
|
||||||
|
|
||||||
def unified_enable(self, node_id, version_spec=None):
|
def unified_enable(self, node_id: str, version_spec=None):
|
||||||
"""
|
"""
|
||||||
priority if version_spec == None
|
priority if version_spec == None
|
||||||
1. CNR latest in disk
|
1. CNR latest in disk
|
||||||
@@ -1009,6 +1028,9 @@ class UnifiedManager:
|
|||||||
|
|
||||||
result = ManagedResult('enable')
|
result = ManagedResult('enable')
|
||||||
|
|
||||||
|
if 'comfyui-manager' in node_id.lower():
|
||||||
|
return result.fail(f"ignored: enabling '{node_id}'")
|
||||||
|
|
||||||
if version_spec is None:
|
if version_spec is None:
|
||||||
version_spec = self.resolve_unspecified_version(node_id, guess_mode='inactive')
|
version_spec = self.resolve_unspecified_version(node_id, guess_mode='inactive')
|
||||||
if version is None:
|
if version is None:
|
||||||
@@ -1074,9 +1096,12 @@ class UnifiedManager:
|
|||||||
self.active_nodes[node_id] = version_spec, to_path
|
self.active_nodes[node_id] = version_spec, to_path
|
||||||
return result.with_target(to_path)
|
return result.with_target(to_path)
|
||||||
|
|
||||||
def unified_disable(self, node_id, is_unknown):
|
def unified_disable(self, node_id: str, is_unknown):
|
||||||
result = ManagedResult('disable')
|
result = ManagedResult('disable')
|
||||||
|
|
||||||
|
if 'comfyui-manager' in node_id.lower():
|
||||||
|
return result.fail(f"ignored: disabling '{node_id}'")
|
||||||
|
|
||||||
if is_unknown:
|
if is_unknown:
|
||||||
version_spec = 'unknown'
|
version_spec = 'unknown'
|
||||||
else:
|
else:
|
||||||
@@ -1132,6 +1157,9 @@ class UnifiedManager:
|
|||||||
"""
|
"""
|
||||||
result = ManagedResult('uninstall')
|
result = ManagedResult('uninstall')
|
||||||
|
|
||||||
|
if 'comfyui-manager' in node_id.lower():
|
||||||
|
return result.fail(f"ignored: uninstalling '{node_id}'")
|
||||||
|
|
||||||
if is_unknown:
|
if is_unknown:
|
||||||
# remove from actives
|
# remove from actives
|
||||||
repo_and_path = self.unknown_active_nodes.get(node_id)
|
repo_and_path = self.unknown_active_nodes.get(node_id)
|
||||||
@@ -1164,14 +1192,14 @@ class UnifiedManager:
|
|||||||
ver_and_path = self.active_nodes.get(node_id)
|
ver_and_path = self.active_nodes.get(node_id)
|
||||||
|
|
||||||
if ver_and_path is not None and os.path.exists(ver_and_path[1]):
|
if ver_and_path is not None and os.path.exists(ver_and_path[1]):
|
||||||
shutil.rmtree(ver_and_path[1])
|
try_rmtree(node_id, ver_and_path[1])
|
||||||
result.items.append(ver_and_path)
|
result.items.append(ver_and_path)
|
||||||
del self.active_nodes[node_id]
|
del self.active_nodes[node_id]
|
||||||
|
|
||||||
# remove from nightly inactives
|
# remove from nightly inactives
|
||||||
fullpath = self.nightly_inactive_nodes.get(node_id)
|
fullpath = self.nightly_inactive_nodes.get(node_id)
|
||||||
if fullpath is not None and os.path.exists(fullpath):
|
if fullpath is not None and os.path.exists(fullpath):
|
||||||
shutil.rmtree(fullpath)
|
try_rmtree(node_id, fullpath)
|
||||||
result.items.append(('nightly', fullpath))
|
result.items.append(('nightly', fullpath))
|
||||||
del self.nightly_inactive_nodes[node_id]
|
del self.nightly_inactive_nodes[node_id]
|
||||||
|
|
||||||
@@ -1179,7 +1207,7 @@ class UnifiedManager:
|
|||||||
ver_map = self.cnr_inactive_nodes.get(node_id)
|
ver_map = self.cnr_inactive_nodes.get(node_id)
|
||||||
if ver_map is not None:
|
if ver_map is not None:
|
||||||
for key, fullpath in ver_map.items():
|
for key, fullpath in ver_map.items():
|
||||||
shutil.rmtree(fullpath)
|
try_rmtree(node_id, fullpath)
|
||||||
result.items.append((key, fullpath))
|
result.items.append((key, fullpath))
|
||||||
del self.cnr_inactive_nodes[node_id]
|
del self.cnr_inactive_nodes[node_id]
|
||||||
|
|
||||||
@@ -1188,9 +1216,12 @@ class UnifiedManager:
|
|||||||
|
|
||||||
return result
|
return result
|
||||||
|
|
||||||
def cnr_install(self, node_id, version_spec=None, instant_execution=False, no_deps=False, return_postinstall=False):
|
def cnr_install(self, node_id: str, version_spec=None, instant_execution=False, no_deps=False, return_postinstall=False):
|
||||||
result = ManagedResult('install-cnr')
|
result = ManagedResult('install-cnr')
|
||||||
|
|
||||||
|
if 'comfyui-manager' in node_id.lower():
|
||||||
|
return result.fail(f"ignored: installing '{node_id}'")
|
||||||
|
|
||||||
node_info = cnr_utils.install_node(node_id, version_spec)
|
node_info = cnr_utils.install_node(node_id, version_spec)
|
||||||
if node_info is None or not node_info.download_url:
|
if node_info is None or not node_info.download_url:
|
||||||
return result.fail(f'not available node: {node_id}@{version_spec}')
|
return result.fail(f'not available node: {node_id}@{version_spec}')
|
||||||
@@ -1235,10 +1266,13 @@ class UnifiedManager:
|
|||||||
|
|
||||||
return result
|
return result
|
||||||
|
|
||||||
def repo_install(self, url, repo_path, instant_execution=False, no_deps=False, return_postinstall=False):
|
def repo_install(self, url: str, repo_path: str, instant_execution=False, no_deps=False, return_postinstall=False):
|
||||||
result = ManagedResult('install-git')
|
result = ManagedResult('install-git')
|
||||||
result.append(url)
|
result.append(url)
|
||||||
|
|
||||||
|
if 'comfyui-manager' in url.lower():
|
||||||
|
return result.fail(f"ignored: installing '{url}'")
|
||||||
|
|
||||||
if not is_valid_url(url):
|
if not is_valid_url(url):
|
||||||
return result.fail(f"Invalid git url: {url}")
|
return result.fail(f"Invalid git url: {url}")
|
||||||
|
|
||||||
@@ -1359,7 +1393,7 @@ class UnifiedManager:
|
|||||||
else:
|
else:
|
||||||
return self.cnr_switch_version(node_id, instant_execution=instant_execution, no_deps=no_deps, return_postinstall=return_postinstall).with_ver('cnr')
|
return self.cnr_switch_version(node_id, instant_execution=instant_execution, no_deps=no_deps, return_postinstall=return_postinstall).with_ver('cnr')
|
||||||
|
|
||||||
async def install_by_id(self, node_id, version_spec=None, channel=None, mode=None, instant_execution=False, no_deps=False, return_postinstall=False):
|
async def install_by_id(self, node_id: str, version_spec=None, channel=None, mode=None, instant_execution=False, no_deps=False, return_postinstall=False):
|
||||||
"""
|
"""
|
||||||
priority if version_spec == None
|
priority if version_spec == None
|
||||||
1. CNR latest
|
1. CNR latest
|
||||||
@@ -1368,6 +1402,9 @@ class UnifiedManager:
|
|||||||
remark: latest version_spec is not allowed. Must be resolved before call.
|
remark: latest version_spec is not allowed. Must be resolved before call.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
if 'comfyui-manager' in node_id.lower():
|
||||||
|
return ManagedResult('skip').fail(f"ignored: installing '{node_id}'")
|
||||||
|
|
||||||
repo_url = None
|
repo_url = None
|
||||||
if version_spec is None:
|
if version_spec is None:
|
||||||
if self.is_enabled(node_id):
|
if self.is_enabled(node_id):
|
||||||
@@ -1596,7 +1633,8 @@ def write_config():
|
|||||||
'security_level': get_config()['security_level'],
|
'security_level': get_config()['security_level'],
|
||||||
'skip_migration_check': get_config()['skip_migration_check'],
|
'skip_migration_check': get_config()['skip_migration_check'],
|
||||||
'always_lazy_install': get_config()['always_lazy_install'],
|
'always_lazy_install': get_config()['always_lazy_install'],
|
||||||
'network_mode': get_config()['network_mode']
|
'network_mode': get_config()['network_mode'],
|
||||||
|
'db_mode': get_config()['db_mode'],
|
||||||
}
|
}
|
||||||
|
|
||||||
directory = os.path.dirname(manager_config_path)
|
directory = os.path.dirname(manager_config_path)
|
||||||
@@ -1636,6 +1674,7 @@ def read_config():
|
|||||||
'always_lazy_install': get_bool('always_lazy_install', False),
|
'always_lazy_install': get_bool('always_lazy_install', False),
|
||||||
'network_mode': default_conf.get('network_mode', 'public').lower(),
|
'network_mode': default_conf.get('network_mode', 'public').lower(),
|
||||||
'security_level': default_conf.get('security_level', 'normal').lower(),
|
'security_level': default_conf.get('security_level', 'normal').lower(),
|
||||||
|
'db_mode': default_conf.get('db_mode', 'cache').lower(),
|
||||||
}
|
}
|
||||||
|
|
||||||
except Exception:
|
except Exception:
|
||||||
@@ -1659,6 +1698,7 @@ def read_config():
|
|||||||
'always_lazy_install': False,
|
'always_lazy_install': False,
|
||||||
'network_mode': 'public', # public | private | offline
|
'network_mode': 'public', # public | private | offline
|
||||||
'security_level': 'normal', # strong | normal | normal- | weak
|
'security_level': 'normal', # strong | normal | normal- | weak
|
||||||
|
'db_mode': 'cache', # local | cache | remote
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -1729,18 +1769,29 @@ def switch_to_default_branch(repo):
|
|||||||
return False
|
return False
|
||||||
|
|
||||||
|
|
||||||
|
def reserve_script(repo_path, install_cmds):
|
||||||
|
if not os.path.exists(manager_startup_script_path):
|
||||||
|
os.makedirs(manager_startup_script_path)
|
||||||
|
|
||||||
|
script_path = os.path.join(manager_startup_script_path, "install-scripts.txt")
|
||||||
|
with open(script_path, "a") as file:
|
||||||
|
obj = [repo_path] + install_cmds
|
||||||
|
file.write(f"{obj}\n")
|
||||||
|
|
||||||
|
|
||||||
|
def try_rmtree(title, fullpath):
|
||||||
|
try:
|
||||||
|
shutil.rmtree(fullpath)
|
||||||
|
except Exception as e:
|
||||||
|
logging.warning(f"[ComfyUI-Manager] An error occurred while deleting '{fullpath}', so it has been scheduled for deletion upon restart.\nEXCEPTION: {e}")
|
||||||
|
reserve_script(title, ["#LAZY-DELETE-NODEPACK", fullpath])
|
||||||
|
|
||||||
|
|
||||||
def try_install_script(url, repo_path, install_cmd, instant_execution=False):
|
def try_install_script(url, repo_path, install_cmd, instant_execution=False):
|
||||||
if not instant_execution and (
|
if not instant_execution and (
|
||||||
(len(install_cmd) > 0 and install_cmd[0].startswith('#')) or platform.system() == "Windows" or get_config()['always_lazy_install']
|
(len(install_cmd) > 0 and install_cmd[0].startswith('#')) or platform.system() == "Windows" or get_config()['always_lazy_install']
|
||||||
):
|
):
|
||||||
if not os.path.exists(manager_startup_script_path):
|
reserve_script(repo_path, install_cmd)
|
||||||
os.makedirs(manager_startup_script_path)
|
|
||||||
|
|
||||||
script_path = os.path.join(manager_startup_script_path, "install-scripts.txt")
|
|
||||||
with open(script_path, "a") as file:
|
|
||||||
obj = [repo_path] + install_cmd
|
|
||||||
file.write(f"{obj}\n")
|
|
||||||
|
|
||||||
return True
|
return True
|
||||||
else:
|
else:
|
||||||
if len(install_cmd) == 5 and install_cmd[2:4] == ['pip', 'install']:
|
if len(install_cmd) == 5 and install_cmd[2:4] == ['pip', 'install']:
|
||||||
@@ -1851,7 +1902,7 @@ def execute_install_script(url, repo_path, lazy_mode=False, instant_execution=Fa
|
|||||||
else:
|
else:
|
||||||
if os.path.exists(requirements_path) and not no_deps:
|
if os.path.exists(requirements_path) and not no_deps:
|
||||||
print("Install: pip packages")
|
print("Install: pip packages")
|
||||||
pip_fixer = manager_util.PIPFixer(manager_util.get_installed_packages())
|
pip_fixer = manager_util.PIPFixer(manager_util.get_installed_packages(), comfy_path, manager_files_path)
|
||||||
with open(requirements_path, "r") as requirements_file:
|
with open(requirements_path, "r") as requirements_file:
|
||||||
for line in requirements_file:
|
for line in requirements_file:
|
||||||
#handle comments
|
#handle comments
|
||||||
@@ -2378,7 +2429,14 @@ def gitclone_update(files, instant_execution=False, skip_script=False, msg_prefi
|
|||||||
def update_to_stable_comfyui(repo_path):
|
def update_to_stable_comfyui(repo_path):
|
||||||
try:
|
try:
|
||||||
repo = git.Repo(repo_path)
|
repo = git.Repo(repo_path)
|
||||||
repo.git.checkout(repo.heads.master)
|
try:
|
||||||
|
repo.git.checkout(repo.heads.master)
|
||||||
|
except:
|
||||||
|
logging.error(f"[ComfyUI-Manager] Failed to checkout 'master' branch.\nrepo_path={repo_path}\nAvailable branches:")
|
||||||
|
for branch in repo.branches:
|
||||||
|
logging.error('\t'+branch.name)
|
||||||
|
return "fail", None
|
||||||
|
|
||||||
versions, current_tag, _ = get_comfyui_versions(repo)
|
versions, current_tag, _ = get_comfyui_versions(repo)
|
||||||
|
|
||||||
if len(versions) == 0 or (len(versions) == 1 and versions[0] == 'nightly'):
|
if len(versions) == 0 or (len(versions) == 1 and versions[0] == 'nightly'):
|
||||||
@@ -2551,14 +2609,11 @@ async def get_current_snapshot(custom_nodes_only = False):
|
|||||||
# Get ComfyUI hash
|
# Get ComfyUI hash
|
||||||
repo_path = comfy_path
|
repo_path = comfy_path
|
||||||
|
|
||||||
if not os.path.exists(os.path.join(repo_path, '.git')):
|
|
||||||
print("ComfyUI update fail: The installed ComfyUI does not have a Git repository.")
|
|
||||||
return {}
|
|
||||||
|
|
||||||
comfyui_commit_hash = None
|
comfyui_commit_hash = None
|
||||||
if not custom_nodes_only:
|
if not custom_nodes_only:
|
||||||
repo = git.Repo(repo_path)
|
if os.path.exists(os.path.join(repo_path, '.git')):
|
||||||
comfyui_commit_hash = repo.head.commit.hexsha
|
repo = git.Repo(repo_path)
|
||||||
|
comfyui_commit_hash = repo.head.commit.hexsha
|
||||||
|
|
||||||
git_custom_nodes = {}
|
git_custom_nodes = {}
|
||||||
cnr_custom_nodes = {}
|
cnr_custom_nodes = {}
|
||||||
@@ -3039,6 +3094,10 @@ async def restore_snapshot(snapshot_path, git_helper_extras=None):
|
|||||||
|
|
||||||
# normalize github repo
|
# normalize github repo
|
||||||
for k, v in _git_info.items():
|
for k, v in _git_info.items():
|
||||||
|
# robust filter out comfyui-manager while restoring snapshot
|
||||||
|
if 'comfyui-manager' in k.lower():
|
||||||
|
continue
|
||||||
|
|
||||||
norm_k = git_utils.normalize_url(k)
|
norm_k = git_utils.normalize_url(k)
|
||||||
git_info[norm_k] = v
|
git_info[norm_k] = v
|
||||||
|
|
||||||
|
|||||||
@@ -190,6 +190,9 @@ def set_component_policy(mode):
|
|||||||
def set_update_policy(mode):
|
def set_update_policy(mode):
|
||||||
core.get_config()['update_policy'] = mode
|
core.get_config()['update_policy'] = mode
|
||||||
|
|
||||||
|
def set_db_mode(mode):
|
||||||
|
core.get_config()['db_mode'] = mode
|
||||||
|
|
||||||
def print_comfyui_version():
|
def print_comfyui_version():
|
||||||
global comfy_ui_hash
|
global comfy_ui_hash
|
||||||
global comfyui_tag
|
global comfyui_tag
|
||||||
@@ -447,7 +450,7 @@ async def task_worker():
|
|||||||
return base_res
|
return base_res
|
||||||
|
|
||||||
base_res['msg'] = f"An error occurred while updating '{node_name}'."
|
base_res['msg'] = f"An error occurred while updating '{node_name}'."
|
||||||
logging.error(f"\nERROR: An error occurred while updating '{node_name}'.")
|
logging.error(f"\nERROR: An error occurred while updating '{node_name}'. (res.result={res.result}, res.action={res.action})")
|
||||||
return base_res
|
return base_res
|
||||||
except Exception:
|
except Exception:
|
||||||
traceback.print_exc()
|
traceback.print_exc()
|
||||||
@@ -464,8 +467,8 @@ async def task_worker():
|
|||||||
res = core.update_path(repo_path)
|
res = core.update_path(repo_path)
|
||||||
|
|
||||||
if res == "fail":
|
if res == "fail":
|
||||||
logging.error("ComfyUI update fail: The installed ComfyUI does not have a Git repository.")
|
logging.error("ComfyUI update failed")
|
||||||
return "The installed ComfyUI does not have a Git repository."
|
return "fail"
|
||||||
elif res == "updated":
|
elif res == "updated":
|
||||||
if is_stable:
|
if is_stable:
|
||||||
logging.info("ComfyUI is updated to latest stable version.")
|
logging.info("ComfyUI is updated to latest stable version.")
|
||||||
@@ -816,7 +819,7 @@ async def fetch_customnode_list(request):
|
|||||||
"""
|
"""
|
||||||
provide unified custom node list
|
provide unified custom node list
|
||||||
"""
|
"""
|
||||||
if "skip_update" in request.rel_url.query and request.rel_url.query["skip_update"] == "true":
|
if request.rel_url.query.get("skip_update", '').lower() == "true":
|
||||||
skip_update = True
|
skip_update = True
|
||||||
else:
|
else:
|
||||||
skip_update = False
|
skip_update = False
|
||||||
@@ -833,7 +836,7 @@ async def fetch_customnode_list(request):
|
|||||||
core.populate_github_stats(node_packs, await json_obj_github)
|
core.populate_github_stats(node_packs, await json_obj_github)
|
||||||
core.populate_favorites(node_packs, await json_obj_extras)
|
core.populate_favorites(node_packs, await json_obj_extras)
|
||||||
|
|
||||||
check_state_of_git_node_pack(node_packs, False, do_update_check=not skip_update)
|
check_state_of_git_node_pack(node_packs, not skip_update, do_update_check=not skip_update)
|
||||||
|
|
||||||
for v in node_packs.values():
|
for v in node_packs.values():
|
||||||
populate_markdown(v)
|
populate_markdown(v)
|
||||||
@@ -1195,7 +1198,15 @@ async def install_custom_node(request):
|
|||||||
git_url = None
|
git_url = None
|
||||||
|
|
||||||
if json_data['version'] != 'unknown':
|
if json_data['version'] != 'unknown':
|
||||||
selected_version = json_data.get('selected_version', 'latest')
|
selected_version = json_data.get('selected_version')
|
||||||
|
|
||||||
|
if skip_post_install:
|
||||||
|
if cnr_id in core.unified_manager.nightly_inactive_nodes or cnr_id in core.unified_manager.cnr_inactive_nodes:
|
||||||
|
core.unified_manager.unified_enable(cnr_id)
|
||||||
|
return web.Response(status=200)
|
||||||
|
elif selected_version is None:
|
||||||
|
selected_version = 'latest'
|
||||||
|
|
||||||
if selected_version != 'nightly':
|
if selected_version != 'nightly':
|
||||||
risky_level = 'low'
|
risky_level = 'low'
|
||||||
node_spec_str = f"{cnr_id}@{selected_version}"
|
node_spec_str = f"{cnr_id}@{selected_version}"
|
||||||
@@ -1447,6 +1458,18 @@ async def preview_method(request):
|
|||||||
return web.Response(status=200)
|
return web.Response(status=200)
|
||||||
|
|
||||||
|
|
||||||
|
@routes.get("/manager/db_mode")
|
||||||
|
async def db_mode(request):
|
||||||
|
if "value" in request.rel_url.query:
|
||||||
|
set_db_mode(request.rel_url.query['value'])
|
||||||
|
core.write_config()
|
||||||
|
else:
|
||||||
|
return web.Response(text=core.get_config()['db_mode'], status=200)
|
||||||
|
|
||||||
|
return web.Response(status=200)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@routes.get("/manager/policy/component")
|
@routes.get("/manager/policy/component")
|
||||||
async def component_policy(request):
|
async def component_policy(request):
|
||||||
if "value" in request.rel_url.query:
|
if "value" in request.rel_url.query:
|
||||||
@@ -1522,26 +1545,27 @@ async def get_notice(request):
|
|||||||
|
|
||||||
if match:
|
if match:
|
||||||
markdown_content = match.group(1)
|
markdown_content = match.group(1)
|
||||||
version_tag = core.get_comfyui_tag()
|
version_tag = os.environ.get('__COMFYUI_DESKTOP_VERSION__')
|
||||||
if version_tag is None:
|
if version_tag is not None:
|
||||||
version_tag = os.environ.get('__COMFYUI_DESKTOP_VERSION__')
|
markdown_content += f"<HR>ComfyUI: {version_tag} [Desktop]"
|
||||||
if version_tag is not None:
|
|
||||||
markdown_content += f"<HR>ComfyUI: {version_tag} [Desktop]"
|
|
||||||
else:
|
|
||||||
markdown_content += f"<HR>ComfyUI: {core.comfy_ui_revision}[{comfy_ui_hash[:6]}]({core.comfy_ui_commit_datetime.date()})"
|
|
||||||
else:
|
else:
|
||||||
markdown_content += (f"<HR>ComfyUI: {version_tag}<BR>"
|
version_tag = core.get_comfyui_tag()
|
||||||
f" ({core.comfy_ui_commit_datetime.date()})")
|
if version_tag is None:
|
||||||
|
markdown_content += f"<HR>ComfyUI: {core.comfy_ui_revision}[{comfy_ui_hash[:6]}]({core.comfy_ui_commit_datetime.date()})"
|
||||||
|
else:
|
||||||
|
markdown_content += (f"<HR>ComfyUI: {version_tag}<BR>"
|
||||||
|
f" ({core.comfy_ui_commit_datetime.date()})")
|
||||||
# markdown_content += f"<BR> ()"
|
# markdown_content += f"<BR> ()"
|
||||||
markdown_content += f"<BR>Manager: {core.version_str}"
|
markdown_content += f"<BR>Manager: {core.version_str}"
|
||||||
|
|
||||||
markdown_content = add_target_blank(markdown_content)
|
markdown_content = add_target_blank(markdown_content)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
if core.comfy_ui_commit_datetime == datetime(1900, 1, 1, 0, 0, 0):
|
if '__COMFYUI_DESKTOP_VERSION__' not in os.environ:
|
||||||
markdown_content = '<P style="text-align: center; color:red; background-color:white; font-weight:bold">Your ComfyUI isn\'t git repo.</P>' + markdown_content
|
if core.comfy_ui_commit_datetime == datetime(1900, 1, 1, 0, 0, 0):
|
||||||
elif core.comfy_ui_required_commit_datetime.date() > core.comfy_ui_commit_datetime.date():
|
markdown_content = '<P style="text-align: center; color:red; background-color:white; font-weight:bold">Your ComfyUI isn\'t git repo.</P>' + markdown_content
|
||||||
markdown_content = '<P style="text-align: center; color:red; background-color:white; font-weight:bold">Your ComfyUI is too OUTDATED!!!</P>' + markdown_content
|
elif core.comfy_ui_required_commit_datetime.date() > core.comfy_ui_commit_datetime.date():
|
||||||
|
markdown_content = '<P style="text-align: center; color:red; background-color:white; font-weight:bold">Your ComfyUI is too OUTDATED!!!</P>' + markdown_content
|
||||||
except:
|
except:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
@@ -1576,7 +1600,10 @@ def restart(self):
|
|||||||
if '--windows-standalone-build' in sys_argv:
|
if '--windows-standalone-build' in sys_argv:
|
||||||
sys_argv.remove('--windows-standalone-build')
|
sys_argv.remove('--windows-standalone-build')
|
||||||
|
|
||||||
if sys.platform.startswith('win32'):
|
if sys_argv[0].endswith("__main__.py"): # this is a python module
|
||||||
|
module_name = os.path.basename(os.path.dirname(sys_argv[0]))
|
||||||
|
cmds = [sys.executable, '-m', module_name] + sys_argv[1:]
|
||||||
|
elif sys.platform.startswith('win32'):
|
||||||
cmds = ['"' + sys.executable + '"', '"' + sys_argv[0] + '"'] + sys_argv[1:]
|
cmds = ['"' + sys.executable + '"', '"' + sys_argv[0] + '"'] + sys_argv[1:]
|
||||||
else:
|
else:
|
||||||
cmds = [sys.executable] + sys_argv
|
cmds = [sys.executable] + sys_argv
|
||||||
@@ -1670,20 +1697,24 @@ cm_global.register_api('cm.try-install-custom-node', confirm_try_install)
|
|||||||
async def default_cache_update():
|
async def default_cache_update():
|
||||||
channel_url = core.get_config()['channel_url']
|
channel_url = core.get_config()['channel_url']
|
||||||
async def get_cache(filename):
|
async def get_cache(filename):
|
||||||
if core.get_config()['default_cache_as_channel_url']:
|
try:
|
||||||
uri = f"{channel_url}/{filename}"
|
if core.get_config()['default_cache_as_channel_url']:
|
||||||
else:
|
uri = f"{channel_url}/{filename}"
|
||||||
uri = f"{core.DEFAULT_CHANNEL}/{filename}"
|
else:
|
||||||
|
uri = f"{core.DEFAULT_CHANNEL}/{filename}"
|
||||||
|
|
||||||
cache_uri = str(manager_util.simple_hash(uri)) + '_' + filename
|
cache_uri = str(manager_util.simple_hash(uri)) + '_' + filename
|
||||||
cache_uri = os.path.join(manager_util.cache_dir, cache_uri)
|
cache_uri = os.path.join(manager_util.cache_dir, cache_uri)
|
||||||
|
|
||||||
json_obj = await manager_util.get_data(uri, True)
|
json_obj = await manager_util.get_data(uri, True)
|
||||||
|
|
||||||
with manager_util.cache_lock:
|
with manager_util.cache_lock:
|
||||||
with open(cache_uri, "w", encoding='utf-8') as file:
|
with open(cache_uri, "w", encoding='utf-8') as file:
|
||||||
json.dump(json_obj, file, indent=4, sort_keys=True)
|
json.dump(json_obj, file, indent=4, sort_keys=True)
|
||||||
logging.info(f"[ComfyUI-Manager] default cache updated: {uri}")
|
logging.info(f"[ComfyUI-Manager] default cache updated: {uri}")
|
||||||
|
except Exception as e:
|
||||||
|
logging.error(f"[ComfyUI-Manager] Failed to perform initial fetching '{filename}': {e}")
|
||||||
|
traceback.print_exc()
|
||||||
|
|
||||||
if core.get_config()['network_mode'] != 'offline':
|
if core.get_config()['network_mode'] != 'offline':
|
||||||
a = get_cache("custom-node-list.json")
|
a = get_cache("custom-node-list.json")
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
description:
|
description:
|
||||||
`manager_util` is the lightest module shared across the prestartup_script, main code, and cm-cli of ComfyUI-Manager.
|
`manager_util` is the lightest module shared across the prestartup_script, main code, and cm-cli of ComfyUI-Manager.
|
||||||
"""
|
"""
|
||||||
|
import traceback
|
||||||
|
|
||||||
import aiohttp
|
import aiohttp
|
||||||
import json
|
import json
|
||||||
@@ -12,6 +13,8 @@ import subprocess
|
|||||||
import sys
|
import sys
|
||||||
import re
|
import re
|
||||||
import logging
|
import logging
|
||||||
|
import platform
|
||||||
|
import shlex
|
||||||
|
|
||||||
|
|
||||||
cache_lock = threading.Lock()
|
cache_lock = threading.Lock()
|
||||||
@@ -21,6 +24,16 @@ cache_dir = os.path.join(comfyui_manager_path, '.cache') # This path is also up
|
|||||||
|
|
||||||
use_uv = False
|
use_uv = False
|
||||||
|
|
||||||
|
|
||||||
|
def add_python_path_to_env():
|
||||||
|
if platform.system() != "Windows":
|
||||||
|
sep = ':'
|
||||||
|
else:
|
||||||
|
sep = ';'
|
||||||
|
|
||||||
|
os.environ['PATH'] = os.path.dirname(sys.executable)+sep+os.environ['PATH']
|
||||||
|
|
||||||
|
|
||||||
def make_pip_cmd(cmd):
|
def make_pip_cmd(cmd):
|
||||||
if use_uv:
|
if use_uv:
|
||||||
return [sys.executable, '-m', 'uv', 'pip'] + cmd
|
return [sys.executable, '-m', 'uv', 'pip'] + cmd
|
||||||
@@ -169,7 +182,7 @@ def save_to_cache(uri, json_obj, silent=False):
|
|||||||
logging.info(f"[ComfyUI-Manager] default cache updated: {uri}")
|
logging.info(f"[ComfyUI-Manager] default cache updated: {uri}")
|
||||||
|
|
||||||
|
|
||||||
async def get_data_with_cache(uri, silent=False, cache_mode=True, dont_wait=False):
|
async def get_data_with_cache(uri, silent=False, cache_mode=True, dont_wait=False, dont_cache=False):
|
||||||
cache_uri = get_cache_path(uri)
|
cache_uri = get_cache_path(uri)
|
||||||
|
|
||||||
if cache_mode and dont_wait:
|
if cache_mode and dont_wait:
|
||||||
@@ -188,11 +201,12 @@ async def get_data_with_cache(uri, silent=False, cache_mode=True, dont_wait=Fals
|
|||||||
json_obj = await get_data(cache_uri, silent=silent)
|
json_obj = await get_data(cache_uri, silent=silent)
|
||||||
else:
|
else:
|
||||||
json_obj = await get_data(uri, silent=silent)
|
json_obj = await get_data(uri, silent=silent)
|
||||||
with cache_lock:
|
if not dont_cache:
|
||||||
with open(cache_uri, "w", encoding='utf-8') as file:
|
with cache_lock:
|
||||||
json.dump(json_obj, file, indent=4, sort_keys=True)
|
with open(cache_uri, "w", encoding='utf-8') as file:
|
||||||
if not silent:
|
json.dump(json_obj, file, indent=4, sort_keys=True)
|
||||||
logging.info(f"[ComfyUI-Manager] default cache updated: {uri}")
|
if not silent:
|
||||||
|
logging.info(f"[ComfyUI-Manager] default cache updated: {uri}")
|
||||||
|
|
||||||
return json_obj
|
return json_obj
|
||||||
|
|
||||||
@@ -232,7 +246,8 @@ def get_installed_packages(renew=False):
|
|||||||
if y[0] == 'Package' or y[0].startswith('-'):
|
if y[0] == 'Package' or y[0].startswith('-'):
|
||||||
continue
|
continue
|
||||||
|
|
||||||
pip_map[y[0]] = y[1]
|
normalized_name = y[0].lower().replace('-', '_')
|
||||||
|
pip_map[normalized_name] = y[1]
|
||||||
except subprocess.CalledProcessError:
|
except subprocess.CalledProcessError:
|
||||||
logging.error("[ComfyUI-Manager] Failed to retrieve the information of installed pip packages.")
|
logging.error("[ComfyUI-Manager] Failed to retrieve the information of installed pip packages.")
|
||||||
return set()
|
return set()
|
||||||
@@ -245,6 +260,46 @@ def clear_pip_cache():
|
|||||||
pip_map = None
|
pip_map = None
|
||||||
|
|
||||||
|
|
||||||
|
def parse_requirement_line(line):
|
||||||
|
tokens = shlex.split(line)
|
||||||
|
if not tokens:
|
||||||
|
return None
|
||||||
|
|
||||||
|
package_spec = tokens[0]
|
||||||
|
|
||||||
|
pattern = re.compile(
|
||||||
|
r'^(?P<package>[A-Za-z0-9_.+-]+)'
|
||||||
|
r'(?P<operator>==|>=|<=|!=|~=|>|<)?'
|
||||||
|
r'(?P<version>[A-Za-z0-9_.+-]*)$'
|
||||||
|
)
|
||||||
|
m = pattern.match(package_spec)
|
||||||
|
if not m:
|
||||||
|
return None
|
||||||
|
|
||||||
|
package = m.group('package')
|
||||||
|
operator = m.group('operator') or None
|
||||||
|
version = m.group('version') or None
|
||||||
|
|
||||||
|
index_url = None
|
||||||
|
if '--index-url' in tokens:
|
||||||
|
idx = tokens.index('--index-url')
|
||||||
|
if idx + 1 < len(tokens):
|
||||||
|
index_url = tokens[idx + 1]
|
||||||
|
|
||||||
|
res = {'package': package}
|
||||||
|
|
||||||
|
if operator is not None:
|
||||||
|
res['operator'] = operator
|
||||||
|
|
||||||
|
if version is not None:
|
||||||
|
res['version'] = StrictVersion(version)
|
||||||
|
|
||||||
|
if index_url is not None:
|
||||||
|
res['index_url'] = index_url
|
||||||
|
|
||||||
|
return res
|
||||||
|
|
||||||
|
|
||||||
torch_torchvision_torchaudio_version_map = {
|
torch_torchvision_torchaudio_version_map = {
|
||||||
'2.6.0': ('0.21.0', '2.6.0'),
|
'2.6.0': ('0.21.0', '2.6.0'),
|
||||||
'2.5.1': ('0.20.0', '2.5.0'),
|
'2.5.1': ('0.20.0', '2.5.0'),
|
||||||
@@ -264,9 +319,12 @@ torch_torchvision_torchaudio_version_map = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class PIPFixer:
|
class PIPFixer:
|
||||||
def __init__(self, prev_pip_versions):
|
def __init__(self, prev_pip_versions, comfyui_path, manager_files_path):
|
||||||
self.prev_pip_versions = { **prev_pip_versions }
|
self.prev_pip_versions = { **prev_pip_versions }
|
||||||
|
self.comfyui_path = comfyui_path
|
||||||
|
self.manager_files_path = manager_files_path
|
||||||
|
|
||||||
def torch_rollback(self):
|
def torch_rollback(self):
|
||||||
spec = self.prev_pip_versions['torch'].split('+')
|
spec = self.prev_pip_versions['torch'].split('+')
|
||||||
@@ -346,7 +404,7 @@ class PIPFixer:
|
|||||||
|
|
||||||
if len(targets) > 0:
|
if len(targets) > 0:
|
||||||
for x in targets:
|
for x in targets:
|
||||||
cmd = make_pip_cmd(['install', f"{x}=={versions[0].version_string}"])
|
cmd = make_pip_cmd(['install', f"{x}=={versions[0].version_string}", "numpy<2"])
|
||||||
subprocess.check_output(cmd, universal_newlines=True)
|
subprocess.check_output(cmd, universal_newlines=True)
|
||||||
|
|
||||||
logging.info(f"[ComfyUI-Manager] 'opencv' dependencies were fixed: {targets}")
|
logging.info(f"[ComfyUI-Manager] 'opencv' dependencies were fixed: {targets}")
|
||||||
@@ -361,10 +419,81 @@ class PIPFixer:
|
|||||||
if StrictVersion(np) >= StrictVersion('2'):
|
if StrictVersion(np) >= StrictVersion('2'):
|
||||||
cmd = make_pip_cmd(['install', "numpy<2"])
|
cmd = make_pip_cmd(['install', "numpy<2"])
|
||||||
subprocess.check_output(cmd , universal_newlines=True)
|
subprocess.check_output(cmd , universal_newlines=True)
|
||||||
|
|
||||||
|
logging.info("[ComfyUI-Manager] 'numpy' dependency were fixed")
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
logging.error("[ComfyUI-Manager] Failed to restore numpy")
|
logging.error("[ComfyUI-Manager] Failed to restore numpy")
|
||||||
logging.error(e)
|
logging.error(e)
|
||||||
|
|
||||||
|
# fix missing frontend
|
||||||
|
try:
|
||||||
|
# NOTE: package name in requirements is 'comfyui-frontend-package'
|
||||||
|
# but, package name from `pip freeze` is 'comfyui_frontend_package'
|
||||||
|
# but, package name from `uv pip freeze` is 'comfyui-frontend-package'
|
||||||
|
#
|
||||||
|
# get_installed_packages returns normalized name (i.e. comfyui_frontend_package)
|
||||||
|
if 'comfyui_frontend_package' not in new_pip_versions:
|
||||||
|
requirements_path = os.path.join(self.comfyui_path, 'requirements.txt')
|
||||||
|
|
||||||
|
with open(requirements_path, 'r') as file:
|
||||||
|
lines = file.readlines()
|
||||||
|
|
||||||
|
front_line = next((line.strip() for line in lines if line.startswith('comfyui-frontend-package')), None)
|
||||||
|
cmd = make_pip_cmd(['install', front_line])
|
||||||
|
subprocess.check_output(cmd , universal_newlines=True)
|
||||||
|
|
||||||
|
logging.info("[ComfyUI-Manager] 'comfyui-frontend-package' dependency were fixed")
|
||||||
|
except Exception as e:
|
||||||
|
logging.error("[ComfyUI-Manager] Failed to restore comfyui-frontend-package")
|
||||||
|
logging.error(e)
|
||||||
|
|
||||||
|
# restore based on custom list
|
||||||
|
pip_auto_fix_path = os.path.join(self.manager_files_path, "pip_auto_fix.list")
|
||||||
|
if os.path.exists(pip_auto_fix_path):
|
||||||
|
with open(pip_auto_fix_path, 'r', encoding="UTF-8", errors="ignore") as f:
|
||||||
|
fixed_list = []
|
||||||
|
|
||||||
|
for x in f.readlines():
|
||||||
|
try:
|
||||||
|
parsed = parse_requirement_line(x)
|
||||||
|
need_to_reinstall = True
|
||||||
|
|
||||||
|
normalized_name = parsed['package'].lower().replace('-', '_')
|
||||||
|
if normalized_name in new_pip_versions:
|
||||||
|
if 'version' in parsed and 'operator' in parsed:
|
||||||
|
cur = StrictVersion(new_pip_versions[parsed['package']])
|
||||||
|
dest = parsed['version']
|
||||||
|
op = parsed['operator']
|
||||||
|
if cur == dest:
|
||||||
|
if op in ['==', '>=', '<=']:
|
||||||
|
need_to_reinstall = False
|
||||||
|
elif cur < dest:
|
||||||
|
if op in ['<=', '<', '~=', '!=']:
|
||||||
|
need_to_reinstall = False
|
||||||
|
elif cur > dest:
|
||||||
|
if op in ['>=', '>', '~=', '!=']:
|
||||||
|
need_to_reinstall = False
|
||||||
|
|
||||||
|
if need_to_reinstall:
|
||||||
|
cmd_args = ['install']
|
||||||
|
if 'version' in parsed and 'operator' in parsed:
|
||||||
|
cmd_args.append(parsed['package']+parsed['operator']+parsed['version'].version_string)
|
||||||
|
|
||||||
|
if 'index_url' in parsed:
|
||||||
|
cmd_args.append('--index-url')
|
||||||
|
cmd_args.append(parsed['index_url'])
|
||||||
|
|
||||||
|
cmd = make_pip_cmd(cmd_args)
|
||||||
|
subprocess.check_output(cmd, universal_newlines=True)
|
||||||
|
|
||||||
|
fixed_list.append(parsed['package'])
|
||||||
|
except Exception as e:
|
||||||
|
traceback.print_exc()
|
||||||
|
logging.error(f"[ComfyUI-Manager] Failed to restore '{x}'")
|
||||||
|
logging.error(e)
|
||||||
|
|
||||||
|
if len(fixed_list) > 0:
|
||||||
|
logging.info(f"[ComfyUI-Manager] dependencies in pip_auto_fix.json were fixed: {fixed_list}")
|
||||||
|
|
||||||
def sanitize(data):
|
def sanitize(data):
|
||||||
return data.replace("<", "<").replace(">", ">")
|
return data.replace("<", "<").replace(">", ">")
|
||||||
|
|||||||
@@ -227,7 +227,6 @@ document.head.appendChild(docStyle);
|
|||||||
|
|
||||||
var update_comfyui_button = null;
|
var update_comfyui_button = null;
|
||||||
var switch_comfyui_button = null;
|
var switch_comfyui_button = null;
|
||||||
var fetch_updates_button = null;
|
|
||||||
var update_all_button = null;
|
var update_all_button = null;
|
||||||
var restart_stop_button = null;
|
var restart_stop_button = null;
|
||||||
var update_policy_combo = null;
|
var update_policy_combo = null;
|
||||||
@@ -653,57 +652,6 @@ async function switchComfyUI() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
async function fetchUpdates(update_check_checkbox) {
|
|
||||||
let prev_text = fetch_updates_button.innerText;
|
|
||||||
fetch_updates_button.innerText = "Fetching updates...";
|
|
||||||
fetch_updates_button.disabled = true;
|
|
||||||
fetch_updates_button.style.backgroundColor = "gray";
|
|
||||||
|
|
||||||
try {
|
|
||||||
var mode = manager_instance.datasrc_combo.value;
|
|
||||||
|
|
||||||
const response = await api.fetchApi(`/customnode/fetch_updates?mode=${mode}`);
|
|
||||||
|
|
||||||
if (response.status != 200 && response.status != 201) {
|
|
||||||
show_message('Failed to fetch updates.');
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (response.status == 201) {
|
|
||||||
show_message("There is an updated extension available.<BR><BR><P><B>NOTE:<BR>Fetch Updates is not an update.<BR>Please update from <button id='cm-install-customnodes-button'>Install Custom Nodes</button> </B></P>");
|
|
||||||
|
|
||||||
const button = document.getElementById('cm-install-customnodes-button');
|
|
||||||
button.addEventListener("click",
|
|
||||||
async function() {
|
|
||||||
app.ui.dialog.close();
|
|
||||||
|
|
||||||
if(!CustomNodesManager.instance) {
|
|
||||||
CustomNodesManager.instance = new CustomNodesManager(app, self);
|
|
||||||
}
|
|
||||||
await CustomNodesManager.instance.show(CustomNodesManager.ShowMode.UPDATE);
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
update_check_checkbox.checked = false;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
show_message('All extensions are already up-to-date with the latest versions.');
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
catch (exception) {
|
|
||||||
show_message(`Failed to update custom nodes / ${exception}`);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
finally {
|
|
||||||
fetch_updates_button.disabled = false;
|
|
||||||
fetch_updates_button.innerText = prev_text;
|
|
||||||
fetch_updates_button.style.backgroundColor = "";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
async function onQueueStatus(event) {
|
async function onQueueStatus(event) {
|
||||||
const isElectron = 'electronAPI' in window;
|
const isElectron = 'electronAPI' in window;
|
||||||
|
|
||||||
@@ -741,7 +689,7 @@ async function onQueueStatus(event) {
|
|||||||
|
|
||||||
let msg = "";
|
let msg = "";
|
||||||
|
|
||||||
if(success_list.length == 0 && !comfyui_state.startsWith('success')) {
|
if(success_list.length == 0 && comfyui_state.startsWith('skip')) {
|
||||||
if(failed_list.length == 0) {
|
if(failed_list.length == 0) {
|
||||||
msg += "You are already up to date.";
|
msg += "You are already up to date.";
|
||||||
}
|
}
|
||||||
@@ -816,8 +764,7 @@ async function onQueueStatus(event) {
|
|||||||
api.addEventListener("cm-queue-status", onQueueStatus);
|
api.addEventListener("cm-queue-status", onQueueStatus);
|
||||||
|
|
||||||
|
|
||||||
async function updateAll(update_comfyui, manager_dialog) {
|
async function updateAll(update_comfyui) {
|
||||||
let prev_text = update_all_button.innerText;
|
|
||||||
update_all_button.innerText = "Updating...";
|
update_all_button.innerText = "Updating...";
|
||||||
|
|
||||||
set_inprogress_mode();
|
set_inprogress_mode();
|
||||||
@@ -900,14 +847,6 @@ class ManagerMenuDialog extends ComfyDialog {
|
|||||||
() => switchComfyUI()
|
() => switchComfyUI()
|
||||||
});
|
});
|
||||||
|
|
||||||
fetch_updates_button =
|
|
||||||
$el("button.cm-button", {
|
|
||||||
type: "button",
|
|
||||||
textContent: "Fetch Updates",
|
|
||||||
onclick:
|
|
||||||
() => fetchUpdates(this.update_check_checkbox)
|
|
||||||
});
|
|
||||||
|
|
||||||
restart_stop_button =
|
restart_stop_button =
|
||||||
$el("button.cm-button-red", {
|
$el("button.cm-button-red", {
|
||||||
type: "button",
|
type: "button",
|
||||||
@@ -921,7 +860,7 @@ class ManagerMenuDialog extends ComfyDialog {
|
|||||||
type: "button",
|
type: "button",
|
||||||
textContent: "Update All Custom Nodes",
|
textContent: "Update All Custom Nodes",
|
||||||
onclick:
|
onclick:
|
||||||
() => updateAll(false, self)
|
() => updateAll(false)
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
@@ -930,7 +869,7 @@ class ManagerMenuDialog extends ComfyDialog {
|
|||||||
type: "button",
|
type: "button",
|
||||||
textContent: "Update All",
|
textContent: "Update All",
|
||||||
onclick:
|
onclick:
|
||||||
() => updateAll(true, self)
|
() => updateAll(true)
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1037,12 +976,6 @@ class ManagerMenuDialog extends ComfyDialog {
|
|||||||
|
|
||||||
let self = this;
|
let self = this;
|
||||||
|
|
||||||
this.update_check_checkbox = $el("input",{type:'checkbox', id:"skip_update_check"},[])
|
|
||||||
const uc_checkbox_text = $el("label",{for:"skip_update_check"},[" Skip update check"])
|
|
||||||
uc_checkbox_text.style.color = "var(--fg-color)";
|
|
||||||
uc_checkbox_text.style.cursor = "pointer";
|
|
||||||
this.update_check_checkbox.checked = true;
|
|
||||||
|
|
||||||
// db mode
|
// db mode
|
||||||
this.datasrc_combo = document.createElement("select");
|
this.datasrc_combo = document.createElement("select");
|
||||||
this.datasrc_combo.setAttribute("title", "Configure where to retrieve node/model information. If set to 'local,' the channel is ignored, and if set to 'channel (remote),' it fetches the latest information each time the list is opened.");
|
this.datasrc_combo.setAttribute("title", "Configure where to retrieve node/model information. If set to 'local,' the channel is ignored, and if set to 'channel (remote),' it fetches the latest information each time the list is opened.");
|
||||||
@@ -1051,6 +984,14 @@ class ManagerMenuDialog extends ComfyDialog {
|
|||||||
this.datasrc_combo.appendChild($el('option', { value: 'local', text: 'DB: Local' }, []));
|
this.datasrc_combo.appendChild($el('option', { value: 'local', text: 'DB: Local' }, []));
|
||||||
this.datasrc_combo.appendChild($el('option', { value: 'remote', text: 'DB: Channel (remote)' }, []));
|
this.datasrc_combo.appendChild($el('option', { value: 'remote', text: 'DB: Channel (remote)' }, []));
|
||||||
|
|
||||||
|
api.fetchApi('/manager/db_mode')
|
||||||
|
.then(response => response.text())
|
||||||
|
.then(data => { this.datasrc_combo.value = data; });
|
||||||
|
|
||||||
|
this.datasrc_combo.addEventListener('change', function (event) {
|
||||||
|
api.fetchApi(`/manager/db_mode?value=${event.target.value}`);
|
||||||
|
});
|
||||||
|
|
||||||
// preview method
|
// preview method
|
||||||
let preview_combo = document.createElement("select");
|
let preview_combo = document.createElement("select");
|
||||||
preview_combo.setAttribute("title", "Configure how latent variables will be decoded during preview in the sampling process.");
|
preview_combo.setAttribute("title", "Configure how latent variables will be decoded during preview in the sampling process.");
|
||||||
@@ -1170,7 +1111,6 @@ class ManagerMenuDialog extends ComfyDialog {
|
|||||||
});
|
});
|
||||||
|
|
||||||
return [
|
return [
|
||||||
$el("div", {}, [this.update_check_checkbox, uc_checkbox_text]),
|
|
||||||
$el("br", {}, []),
|
$el("br", {}, []),
|
||||||
this.datasrc_combo,
|
this.datasrc_combo,
|
||||||
channel_combo,
|
channel_combo,
|
||||||
|
|||||||
@@ -676,7 +676,7 @@ export class CustomNodesManager {
|
|||||||
"invalid-installation": ["reinstall"],
|
"invalid-installation": ["reinstall"],
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!manager_instance.update_check_checkbox.checked) {
|
if (!installGroups.updatable) {
|
||||||
installGroups.enabled = installGroups.enabled.filter(it => it !== "try-update");
|
installGroups.enabled = installGroups.enabled.filter(it => it !== "try-update");
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1584,6 +1584,7 @@ export class CustomNodesManager {
|
|||||||
|
|
||||||
let unresolved_aux_ids = {};
|
let unresolved_aux_ids = {};
|
||||||
let outdated_comfyui = false;
|
let outdated_comfyui = false;
|
||||||
|
let unresolved_cnr_list = [];
|
||||||
|
|
||||||
for(let k in allUsedNodes) {
|
for(let k in allUsedNodes) {
|
||||||
let node = allUsedNodes[k];
|
let node = allUsedNodes[k];
|
||||||
@@ -1596,7 +1597,14 @@ export class CustomNodesManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
let item = this.custom_nodes[node.properties.cnr_id];
|
let item = this.custom_nodes[node.properties.cnr_id];
|
||||||
hashMap[item.hash] = true;
|
if(item) {
|
||||||
|
hashMap[item.hash] = true;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
console.log(`CM: cannot find '${node.properties.cnr_id}' from cnr list.`);
|
||||||
|
unresolved_aux_ids[node.properties.cnr_id] = node.type;
|
||||||
|
unresolved_cnr_list.push(node.properties.cnr_id);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if(node.properties.aux_id) {
|
else if(node.properties.aux_id) {
|
||||||
unresolved_aux_ids[node.properties.aux_id] = node.type;
|
unresolved_aux_ids[node.properties.aux_id] = node.type;
|
||||||
@@ -1607,6 +1615,16 @@ export class CustomNodesManager {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if(unresolved_cnr_list.length > 0) {
|
||||||
|
let error_msg = "Failed to find the following ComfyRegistry list.\nThe cache may be outdated, or the nodes may have been removed from ComfyRegistry.<HR>";
|
||||||
|
for(let i in unresolved_cnr_list) {
|
||||||
|
error_msg += '<li>'+unresolved_cnr_list[i]+'</li>';
|
||||||
|
}
|
||||||
|
|
||||||
|
show_message(error_msg);
|
||||||
|
}
|
||||||
|
|
||||||
if(outdated_comfyui) {
|
if(outdated_comfyui) {
|
||||||
customAlert('ComfyUI is outdated, so some built-in nodes cannot be used.');
|
customAlert('ComfyUI is outdated, so some built-in nodes cannot be used.');
|
||||||
}
|
}
|
||||||
@@ -1640,13 +1658,13 @@ export class CustomNodesManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if(unresolved_missing_nodes.size > 0) {
|
if(unresolved_missing_nodes.size > 0) {
|
||||||
await this.getMissingNodesLegacy(hashMap, unresolved_missing_nodes, registered_nodes);
|
await this.getMissingNodesLegacy(hashMap, unresolved_missing_nodes);
|
||||||
}
|
}
|
||||||
|
|
||||||
return hashMap;
|
return hashMap;
|
||||||
}
|
}
|
||||||
|
|
||||||
async getMissingNodesLegacy(hashMap, missing_nodes, registered_nodes) {
|
async getMissingNodesLegacy(hashMap, missing_nodes) {
|
||||||
const mode = manager_instance.datasrc_combo.value;
|
const mode = manager_instance.datasrc_combo.value;
|
||||||
this.showStatus(`Loading missing nodes (${mode}) ...`);
|
this.showStatus(`Loading missing nodes (${mode}) ...`);
|
||||||
const res = await fetchData(`/customnode/getmappings?mode=${mode}`);
|
const res = await fetchData(`/customnode/getmappings?mode=${mode}`);
|
||||||
@@ -1687,20 +1705,15 @@ export class CustomNodesManager {
|
|||||||
|
|
||||||
let unresolved_missing_nodes = new Set();
|
let unresolved_missing_nodes = new Set();
|
||||||
for (let node_type of missing_nodes) {
|
for (let node_type of missing_nodes) {
|
||||||
if(node_type.startsWith('workflow/') || node_type.startsWith('workflow>'))
|
const packs = name_to_packs[node_type.trim()];
|
||||||
continue;
|
if(packs)
|
||||||
|
packs.forEach(url => {
|
||||||
if (!registered_nodes.has(node_type)) {
|
unresolved_missing_nodes.add(url);
|
||||||
const packs = name_to_packs[node_type.trim()];
|
});
|
||||||
if(packs)
|
else {
|
||||||
packs.forEach(url => {
|
for(let j in regex_to_pack) {
|
||||||
unresolved_missing_nodes.add(url);
|
if(regex_to_pack[j].regex.test(node_type)) {
|
||||||
});
|
unresolved_missing_nodes.add(regex_to_pack[j].url);
|
||||||
else {
|
|
||||||
for(let j in regex_to_pack) {
|
|
||||||
if(regex_to_pack[j].regex.test(node_type)) {
|
|
||||||
unresolved_missing_nodes.add(regex_to_pack[j].url);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -1814,11 +1827,16 @@ export class CustomNodesManager {
|
|||||||
this.showStatus(`Loading custom nodes (${mode}) ...`);
|
this.showStatus(`Loading custom nodes (${mode}) ...`);
|
||||||
|
|
||||||
const skip_update = this.show_mode === ShowMode.UPDATE ? "" : "&skip_update=true";
|
const skip_update = this.show_mode === ShowMode.UPDATE ? "" : "&skip_update=true";
|
||||||
|
|
||||||
|
if(this.show_mode === ShowMode.UPDATE) {
|
||||||
|
infoToast('Fetching updated information. This may take some time if many custom nodes are installed.');
|
||||||
|
}
|
||||||
|
|
||||||
const res = await fetchData(`/customnode/getlist?mode=${mode}${skip_update}`);
|
const res = await fetchData(`/customnode/getlist?mode=${mode}${skip_update}`);
|
||||||
if (res.error) {
|
if (res.error) {
|
||||||
this.showError("Failed to get custom node list.");
|
this.showError("Failed to get custom node list.");
|
||||||
this.hideLoading();
|
this.hideLoading();
|
||||||
return
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
const { channel, node_packs } = res.data;
|
const { channel, node_packs } = res.data;
|
||||||
|
|||||||
@@ -1068,18 +1068,28 @@
|
|||||||
"size": "19.1GB"
|
"size": "19.1GB"
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
||||||
{
|
{
|
||||||
"name": "comfyanonymous/clip_l",
|
"name": "Comfy-Org/clip_l",
|
||||||
"type": "clip",
|
"type": "clip",
|
||||||
"base": "clip",
|
"base": "clip",
|
||||||
"save_path": "default",
|
"save_path": "default",
|
||||||
"description": "clip_l model",
|
"description": "clip_l model (for SD1.x, SD2.x, SDXL, SD3.5, FLUX.1, HunyuanVideo, ...) ",
|
||||||
"reference": "https://huggingface.co/comfyanonymous/flux_text_encoders/tree/main",
|
"reference": "https://huggingface.co/Comfy-Org/stable-diffusion-3.5-fp8",
|
||||||
"filename": "clip_l.safetensors",
|
"filename": "clip_l.safetensors",
|
||||||
"url": "https://huggingface.co/comfyanonymous/flux_text_encoders/resolve/main/clip_l.safetensors",
|
"url": "https://huggingface.co/Comfy-Org/stable-diffusion-3.5-fp8/resolve/main/text_encoders/clip_l.safetensors",
|
||||||
"size": "246MB"
|
"size": "246MB"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "Comfy-Org/clip_g",
|
||||||
|
"type": "clip",
|
||||||
|
"base": "clip",
|
||||||
|
"save_path": "default",
|
||||||
|
"description": "clip_g model (for SDXL, SD3.5)",
|
||||||
|
"reference": "https://huggingface.co/Comfy-Org/stable-diffusion-3.5-fp8",
|
||||||
|
"filename": "clip_g.safetensors",
|
||||||
|
"url": "https://huggingface.co/Comfy-Org/stable-diffusion-3.5-fp8/resolve/main/text_encoders/clip_g.safetensors",
|
||||||
|
"size": "1.39GB"
|
||||||
|
},
|
||||||
|
|
||||||
{
|
{
|
||||||
"name": "v1-5-pruned-emaonly.ckpt",
|
"name": "v1-5-pruned-emaonly.ckpt",
|
||||||
@@ -3950,6 +3960,17 @@
|
|||||||
"url": "https://huggingface.co/Comfy-Org/HunyuanVideo_repackaged/resolve/main/split_files/vae/hunyuan_video_vae_bf16.safetensors",
|
"url": "https://huggingface.co/Comfy-Org/HunyuanVideo_repackaged/resolve/main/split_files/vae/hunyuan_video_vae_bf16.safetensors",
|
||||||
"size": "493MB"
|
"size": "493MB"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "Comfy-Org/hunyuan_video_image_to_video_720p_bf16.safetensors",
|
||||||
|
"type": "diffusion_model",
|
||||||
|
"base": "Hunyuan Video",
|
||||||
|
"save_path": "diffusion_models/hunyuan_video",
|
||||||
|
"description": "Huyuan Video Image2Video diffusion model. repackaged version.",
|
||||||
|
"reference": "https://huggingface.co/Comfy-Org/HunyuanVideo_repackaged",
|
||||||
|
"filename": "hunyuan_video_image_to_video_720p_bf16.safetensors",
|
||||||
|
"url": "https://huggingface.co/Comfy-Org/HunyuanVideo_repackaged/resolve/main/split_files/diffusion_models/hunyuan_video_image_to_video_720p_bf16.safetensors",
|
||||||
|
"size": "25.6GB"
|
||||||
|
},
|
||||||
|
|
||||||
{
|
{
|
||||||
"name": "Comfy-Org/llava_llama3_fp8_scaled.safetensors",
|
"name": "Comfy-Org/llava_llama3_fp8_scaled.safetensors",
|
||||||
@@ -3973,6 +3994,17 @@
|
|||||||
"url": "https://huggingface.co/Comfy-Org/HunyuanVideo_repackaged/resolve/main/split_files/text_encoders/llava_llama3_fp16.safetensors",
|
"url": "https://huggingface.co/Comfy-Org/HunyuanVideo_repackaged/resolve/main/split_files/text_encoders/llava_llama3_fp16.safetensors",
|
||||||
"size": "16.1GB"
|
"size": "16.1GB"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "Comfy-Org/llava_llama3_vision.safetensors",
|
||||||
|
"type": "clip_vision",
|
||||||
|
"base": "LLaVA-Llama-3",
|
||||||
|
"save_path": "text_encoders",
|
||||||
|
"description": "llava_llama3_vision clip vison model. This is required for using Hunyuan Video Image2Video.",
|
||||||
|
"reference": "https://huggingface.co/Comfy-Org/HunyuanVideo_repackaged",
|
||||||
|
"filename": "llava_llama3_vision.safetensors",
|
||||||
|
"url": "https://huggingface.co/Comfy-Org/HunyuanVideo_repackaged/resolve/main/split_files/clip_vision/llava_llama3_vision.safetensors",
|
||||||
|
"size": "649MB"
|
||||||
|
},
|
||||||
|
|
||||||
{
|
{
|
||||||
"name": "FLUX.1 [Schnell] Diffusion model",
|
"name": "FLUX.1 [Schnell] Diffusion model",
|
||||||
@@ -4537,6 +4569,17 @@
|
|||||||
"url": "https://huggingface.co/Lightricks/LTX-Video/resolve/main/ltx-video-2b-v0.9.1.safetensors",
|
"url": "https://huggingface.co/Lightricks/LTX-Video/resolve/main/ltx-video-2b-v0.9.1.safetensors",
|
||||||
"size": "5.72GB"
|
"size": "5.72GB"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "LTX-Video 2B v0.9.5 Checkpoint",
|
||||||
|
"type": "checkpoint",
|
||||||
|
"base": "LTX-Video",
|
||||||
|
"save_path": "checkpoints/LTXV",
|
||||||
|
"description": "LTX-Video is the first DiT-based video generation model capable of generating high-quality videos in real-time. It produces 24 FPS videos at a 768x512 resolution faster than they can be watched. Trained on a large-scale dataset of diverse videos, the model generates high-resolution videos with realistic and varied content.",
|
||||||
|
"reference": "https://huggingface.co/Lightricks/LTX-Video",
|
||||||
|
"filename": "ltx-video-2b-v0.9.5.safetensors",
|
||||||
|
"url": "https://huggingface.co/Lightricks/LTX-Video/resolve/main/ltx-video-2b-v0.9.5.safetensors",
|
||||||
|
"size": "6.34GB"
|
||||||
|
},
|
||||||
|
|
||||||
{
|
{
|
||||||
"name": "XLabs-AI/flux-canny-controlnet-v3.safetensors",
|
"name": "XLabs-AI/flux-canny-controlnet-v3.safetensors",
|
||||||
|
|||||||
@@ -12,7 +12,256 @@
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
{
|
||||||
|
"author": "longzoho",
|
||||||
|
"title": "ComfyUI-Qdrant-Saver",
|
||||||
|
"reference": "https://github.com/longzoho/ComfyUI-Qdrant-Saver",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/longzoho/ComfyUI-Qdrant-Saver"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "NODES: QDrant Saver Node"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "nova-florealis",
|
||||||
|
"title": "comfyui-alien",
|
||||||
|
"reference": "https://github.com/nova-florealis/comfyui-alien",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/nova-florealis/comfyui-alien"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "NODES: Text to Text (LLM), Text Output, Convert to Markdown, List Display (Debug)"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "RUFFY-369",
|
||||||
|
"title": "ComfyUI-FeatureBank",
|
||||||
|
"reference": "https://github.com/RUFFY-369/ComfyUI-FeatureBank",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/RUFFY-369/ComfyUI-FeatureBank"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "NODES: FeatureBankAttentionProcessor"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "Pablerdo",
|
||||||
|
"title": "ComfyUI-Sa2VAWrapper",
|
||||||
|
"reference": "https://github.com/Pablerdo/ComfyUI-Sa2VAWrapper",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/Pablerdo/ComfyUI-Sa2VAWrapper"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Wrapper for the Sa2VA model"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "S4MUEL-404",
|
||||||
|
"title": "ComfyUI-Folder-Images-Preview [UNSAFE]",
|
||||||
|
"reference": "https://github.com/S4MUEL-404/ComfyUI-Folder-Images-Preview",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/S4MUEL-404/ComfyUI-Folder-Images-Preview"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A ComfyUI nodes , Generate a picture and quickly preview the pictures in the folder and the picture file name\n[w/This custom node has a path traversal vulnerability.]"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "aria1th",
|
||||||
|
"title": "ComfyUI-camietagger-onnx",
|
||||||
|
"reference": "https://github.com/aria1th/ComfyUI-camietagger-onnx",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/aria1th/ComfyUI-camietagger-onnx"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "NODES: Camie Tagger"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "zjkhurry",
|
||||||
|
"title": "comfyui_MetalFX [WIP]",
|
||||||
|
"reference": "https://github.com/zjkhurry/comfyui_MetalFX",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/zjkhurry/comfyui_MetalFX"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A custom node for ComfyUI that enables high-quality image and video upscaling using Apple MetalFX technology.\nNOTE: The files in the repo are not organized."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "IfnotFr",
|
||||||
|
"title": "ComfyUI-Connect [WIP]",
|
||||||
|
"reference": "https://github.com/IfnotFr/ComfyUI-Connect",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/IfnotFr/ComfyUI-Connect"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Transform your ComfyUI into a powerful API, exposing all your saved workflows as ready-to-use HTTP endpoints."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "RoyKillington",
|
||||||
|
"title": "Miscomfy Nodes [WIP]",
|
||||||
|
"reference": "https://github.com/RoyKillington/miscomfy-nodes",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/RoyKillington/miscomfy-nodes"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A repo of custom nodes for ComfyUI, from interacting with certain APIs to whatever other miscellanea I end up making"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "xmarked-ai",
|
||||||
|
"title": "ComfyUI_misc",
|
||||||
|
"reference": "https://github.com/xmarked-ai/ComfyUI_misc",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/xmarked-ai/ComfyUI_misc"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "NODES: Ace IntegerX, Ace FloatX, Ace Color FixX, White Balance X, Depth Displace X, Empty Latent X, KSampler Combo X, ..."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "Elypha",
|
||||||
|
"title": "ComfyUI-Prompt-Helper [WIP]",
|
||||||
|
"reference": "https://github.com/Elypha/ComfyUI-Prompt-Helper",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/Elypha/ComfyUI-Prompt-Helper"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Concat conditions and prompts for ComfyUI"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "StoryWalker",
|
||||||
|
"title": "comfyui_flux_collection_advanced [WIP]",
|
||||||
|
"reference": "https://github.com/StoryWalker/comfyui_flux_collection_advanced",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/StoryWalker/comfyui_flux_collection_advanced"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "This is a collection focused in give a little more flexibility in the use of Flux models."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "KurtHokke",
|
||||||
|
"title": "ComfyUI_KurtHokke-Nodes",
|
||||||
|
"reference": "https://github.com/KurtHokke/ComfyUI_KurtHokke-Nodes",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/KurtHokke/ComfyUI_KurtHokke-Nodes"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "ComfyUI_KurtHokke-Nodes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "OSAnimate",
|
||||||
|
"title": "ComfyUI-SpriteSheetMaker [WIP]",
|
||||||
|
"reference": "https://github.com/OSAnimate/ComfyUI-SpriteSheetMaker",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/OSAnimate/ComfyUI-SpriteSheetMaker"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "The sprite sheet maker node is a simple way to create sprite sheets and image grids.\nNOTE: The files in the repo are not organized."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "BuffMcBigHuge",
|
||||||
|
"title": "ComfyUI-Buff-Nodes [WIP]",
|
||||||
|
"reference": "https://github.com/BuffMcBigHuge/ComfyUI-Buff-Nodes",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/BuffMcBigHuge/ComfyUI-Buff-Nodes"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Assorted Nodes by BuffMcBigHuge"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "ritikvirus",
|
||||||
|
"title": "ComfyUI Terminal Command Node [UNSAFE]",
|
||||||
|
"reference": "https://github.com/ritikvirus/comfyui-terminal-modal-node",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/ritikvirus/comfyui-terminal-modal-node"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "This repository provides a custom ComfyUI node that lets you execute arbitrary terminal commands directly from the ComfyUI interface. [w/This extension allows remote command execution.]"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "pixuai",
|
||||||
|
"title": "ComfyUI-PixuAI",
|
||||||
|
"reference": "https://github.com/pixuai/ComfyUI-PixuAI",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/pixuai/ComfyUI-PixuAI"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A collection of ComfyUI nodes designed to streamline prompt creation, organization, and discovery - making your workflows faster and more intuitive."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "techidsk",
|
||||||
|
"title": "comfyui_molook_nodes [WIP]",
|
||||||
|
"reference": "https://github.com/techidsk/comfyui_molook_nodes",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/techidsk/comfyui_molook_nodes"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Some extra nodes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "Northerner1",
|
||||||
|
"title": "ComfyUI_North_Noise [WIP]",
|
||||||
|
"reference": "https://github.com/Northerner1/ComfyUI_North_Noise",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/Northerner1/ComfyUI_North_Noise"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "NODES: North Noise"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "ManuShamil",
|
||||||
|
"title": "ComfyUI_BodyEstimation_Nodes",
|
||||||
|
"reference": "https://github.com/ManuShamil/ComfyUI_BodyEstimation_Nodes",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/ManuShamil/ComfyUI_BodyEstimation_Nodes"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "NODES: CogitareLabsPoseIDExtractor"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "MockbaTheBorg",
|
||||||
|
"title": "ComfyUI-Mockba",
|
||||||
|
"reference": "https://github.com/MockbaTheBorg/ComfyUI-Mockba",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/MockbaTheBorg/ComfyUI-Mockba"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "NODES: Image Batch/Flip/Rotate/Subtract/Dither, Barcode, Select, ..."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "jcomeme",
|
||||||
|
"title": "AsunaroTools",
|
||||||
|
"reference": "https://github.com/jcomeme/ComfyUI-AsunaroTools",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/jcomeme/ComfyUI-AsunaroTools"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A collection of custom nodes for ComfyUI"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "ZHO-ZHO-ZHO",
|
||||||
|
"title": "ComfyUI Wan2.1 [WIP]",
|
||||||
|
"reference": "https://github.com/ZHO-ZHO-ZHO/ComfyUI-Wan-ZHO",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/ZHO-ZHO-ZHO/ComfyUI-Wan-ZHO"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "It’s estimated that ComfyUI itself will support it soon, so go ahead and give it a try!"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "kijai",
|
||||||
|
"title": "ComfyUI-WanVideoWrapper [WIP]",
|
||||||
|
"reference": "https://github.com/kijai/ComfyUI-WanVideoWrapper",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/kijai/ComfyUI-WanVideoWrapper"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "ComfyUI diffusers wrapper nodes for WanVideo"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "ltdrdata",
|
||||||
|
"title": "comfyui-unsafe-torch [UNSAFE]",
|
||||||
|
"reference": "https://github.com/ltdrdata/comfyui-unsafe-torch",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/ltdrdata/comfyui-unsafe-torch"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "disable torch.load's `weigths_only`"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"author": "IfnotFr",
|
"author": "IfnotFr",
|
||||||
"title": "⚡ ComfyUI Connect [WIP]",
|
"title": "⚡ ComfyUI Connect [WIP]",
|
||||||
@@ -43,17 +292,6 @@
|
|||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "A comfy node to find faces and output a mask"
|
"description": "A comfy node to find faces and output a mask"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"author": "RiceRound",
|
|
||||||
"title": "RiceRound Cloud Node [UNSAFE]",
|
|
||||||
"id": "riceround",
|
|
||||||
"reference": "https://github.com/RiceRound/ComfyUI_RiceRound",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/RiceRound/ComfyUI_RiceRound"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "This is an imaginative project that allows for one-click deployment, providing both an online page and a ComfyUI cloud node.[w/This custom node is vulnerable because it can dynamically download and execute nodes.]"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"author": "Yeonri",
|
"author": "Yeonri",
|
||||||
"title": "ComfyUI_LLM_Are_You_Listening [WIP]",
|
"title": "ComfyUI_LLM_Are_You_Listening [WIP]",
|
||||||
@@ -528,13 +766,13 @@
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
"author": "HuangYuChuh",
|
"author": "HuangYuChuh",
|
||||||
"title": "ComfyUI-DeepSeek_Toolkit [WIP]",
|
"title": "ComfyUI-DeepSeek-Toolkit [WIP]",
|
||||||
"reference": "https://github.com/HuangYuChuh/ComfyUI-DeepSeek_Toolkit",
|
"reference": "https://github.com/HuangYuChuh/ComfyUI-DeepSeek-Toolkit",
|
||||||
"files": [
|
"files": [
|
||||||
"https://github.com/HuangYuChuh/ComfyUI-DeepSeek_Toolkit"
|
"https://github.com/HuangYuChuh/ComfyUI-DeepSeek-Toolkit"
|
||||||
],
|
],
|
||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "ComfyUI-DeepSeek_Toolkit is a deep learning toolkit for ComfyUI that integrates the DeepSeek Janus model, offering functionalities for image generation and image understanding.\nNOTE: The files in the repo are not organized."
|
"description": "ComfyUI-DeepSeek-Toolkit is a deep learning toolkit for ComfyUI that integrates the DeepSeek Janus model, offering functionalities for image generation and image understanding.\nNOTE: The files in the repo are not organized."
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"author": "comfyuiblog",
|
"author": "comfyuiblog",
|
||||||
@@ -666,16 +904,6 @@
|
|||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "nodes for deepseek api\nNOTE: The files in the repo are not organized."
|
"description": "nodes for deepseek api\nNOTE: The files in the repo are not organized."
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"author": "807502278",
|
|
||||||
"title": "ComfyUI_TensorRT_Merge [WIP]",
|
|
||||||
"reference": "https://github.com/807502278/ComfyUI_TensorRT_Merge",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/807502278/ComfyUI_TensorRT_Merge"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "Non diffusion models supported by TensorRT, merged Comfyui plugin, added onnx automatic download and trt model conversion nodes."
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"author": "IfnotFr",
|
"author": "IfnotFr",
|
||||||
"title": "ComfyUI-Ifnot-Pack",
|
"title": "ComfyUI-Ifnot-Pack",
|
||||||
@@ -1177,16 +1405,6 @@
|
|||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "NODES: File Mv, File Path, File Dir.\n[w/This is dangerous as it provides the ability to manipulate arbitrary user files.]"
|
"description": "NODES: File Mv, File Path, File Dir.\n[w/This is dangerous as it provides the ability to manipulate arbitrary user files.]"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"author": "scottmudge",
|
|
||||||
"title": "ComfyUI_BiscuitNodes",
|
|
||||||
"reference": "https://github.com/scottmudge/ComfyUI_BiscuitNodes",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/scottmudge/ComfyUI_BiscuitNodes"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "Load Image From Path Using File Selector"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"author": "JissiChoi",
|
"author": "JissiChoi",
|
||||||
"title": "ComfyUI-Jissi-List [WIP]",
|
"title": "ComfyUI-Jissi-List [WIP]",
|
||||||
@@ -1851,7 +2069,7 @@
|
|||||||
"https://github.com/aria1th/ComfyUI-SkipCFGSigmas"
|
"https://github.com/aria1th/ComfyUI-SkipCFGSigmas"
|
||||||
],
|
],
|
||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "NODES:CFGControl_SKIPCFG"
|
"description": "NODES: CFGControl_SKIPCFG"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"author": "Clelstyn",
|
"author": "Clelstyn",
|
||||||
@@ -1901,7 +2119,7 @@
|
|||||||
"https://github.com/oshtz/ComfyUI-oshtz-nodes"
|
"https://github.com/oshtz/ComfyUI-oshtz-nodes"
|
||||||
],
|
],
|
||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "Custom nodes for ComfyUI created for some of my workflows.\nLLM All-in-One Node, String Splitter Node, LoRA Switcher Node, Image Overlay Node"
|
"description": "Custom nodes for ComfyUI created for some of my workflows.\nLLM All-in-One Node, String Splitter Node, LoRA Switcher Node, Image Overlay Node\nNOTE: The files in the repo are not organized."
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"author": "m-ai-studio",
|
"author": "m-ai-studio",
|
||||||
@@ -2071,7 +2289,7 @@
|
|||||||
"https://github.com/fablestudio/ComfyUI-Showrunner-Utils"
|
"https://github.com/fablestudio/ComfyUI-Showrunner-Utils"
|
||||||
],
|
],
|
||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "NODES:Align Face, Generate Timestamp"
|
"description": "NODES: Align Face, Generate Timestamp, GetMostCommonColors, Alpha Crop and Position Image, Shrink Image"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"author": "monate0615",
|
"author": "monate0615",
|
||||||
@@ -2739,13 +2957,14 @@
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
"author": "chrisdreid",
|
"author": "chrisdreid",
|
||||||
"title": "ComfyUI_EnvAutopsyAPI [UNSAFE]",
|
"title": "ComfyUI_EnvAutopsyAPI Debugger [UNSAFE]",
|
||||||
|
"id": "chrisdreid",
|
||||||
"reference": "https://github.com/chrisdreid/ComfyUI_EnvAutopsyAPI",
|
"reference": "https://github.com/chrisdreid/ComfyUI_EnvAutopsyAPI",
|
||||||
"files": [
|
"files": [
|
||||||
"https://github.com/chrisdreid/ComfyUI_EnvAutopsyAPI"
|
"https://github.com/chrisdreid/ComfyUI_EnvAutopsyAPI"
|
||||||
],
|
],
|
||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "ComfyUI_EnvAutopsyAPI is a powerful debugging tool designed for ComfyUI that provides in-depth analysis of your environment and dependencies through an API interface. This tool allows you to inspect environment variables, pip packages, and dependency trees, making it easier to diagnose and resolve issues in your ComfyUI setup.[w/This tool may expose sensitive system information if used on a public server. MUST READ [a/THIS](https://github.com/chrisdreid/ComfyUI_EnvAutopsyAPI#%EF%B8%8F-warning-security-risk-%EF%B8%8F) before install.]"
|
"description": "A powerful debugging tool designed to provide in-depth analysis of your environment and dependencies by exposing API endpoints. This tool allows you to inspect environment variables, pip packages, python info and dependency trees, making it easier to diagnose and resolve issues in your ComfyUI setup.[w/This tool may expose sensitive system information if used on a public server]"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"author": "Futureversecom",
|
"author": "Futureversecom",
|
||||||
@@ -2860,16 +3079,6 @@
|
|||||||
"install_type":"git-clone",
|
"install_type":"git-clone",
|
||||||
"description":"The ComfyUI code is under review in the official repository. Meanwhile, a temporary version is available below for immediate community use. We welcome users to try our workflow and appreciate any inquiries or suggestions."
|
"description":"The ComfyUI code is under review in the official repository. Meanwhile, a temporary version is available below for immediate community use. We welcome users to try our workflow and appreciate any inquiries or suggestions."
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"author": "JichaoLiang",
|
|
||||||
"title": "Immortal_comfyUI",
|
|
||||||
"reference": "https://github.com/JichaoLiang/Immortal_comfyUI",
|
|
||||||
"files":[
|
|
||||||
"https://github.com/JichaoLiang/Immortal_comfyUI"
|
|
||||||
],
|
|
||||||
"install_type":"git-clone",
|
|
||||||
"description":"Nodes: NewNode, AppendNode, MergeNode, SetProperties, SaveToDirectory, ..."
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"author": "melMass",
|
"author": "melMass",
|
||||||
"title": "ComfyUI-Lygia",
|
"title": "ComfyUI-Lygia",
|
||||||
|
|||||||
@@ -169,33 +169,13 @@
|
|||||||
"PD_ImageConcanate",
|
"PD_ImageConcanate",
|
||||||
"PD_Image_Crop_Location",
|
"PD_Image_Crop_Location",
|
||||||
"PD_RemoveColorWords",
|
"PD_RemoveColorWords",
|
||||||
|
"ReadTxtFiles",
|
||||||
"json_group_fontsize"
|
"json_group_fontsize"
|
||||||
],
|
],
|
||||||
{
|
{
|
||||||
"title_aux": "comfyui-promptbymood [WIP]"
|
"title_aux": "comfyui-promptbymood [WIP]"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"https://github.com/807502278/ComfyUI_TensorRT_Merge": [
|
|
||||||
[
|
|
||||||
"BiRefNet2_tensort",
|
|
||||||
"BiRefNet_TRT",
|
|
||||||
"Building_TRT",
|
|
||||||
"Custom_Building_TRT",
|
|
||||||
"DepthAnything_Tensorrt",
|
|
||||||
"Dwpose_Tensorrt",
|
|
||||||
"FaceRestoreTensorrt",
|
|
||||||
"RifeTensorrt",
|
|
||||||
"UpscalerTensorrt",
|
|
||||||
"YoloNasPoseTensorrt",
|
|
||||||
"load_BiRefNet2_tensort",
|
|
||||||
"load_BiRefNet_TRT",
|
|
||||||
"load_DepthAnything_Tensorrt",
|
|
||||||
"load_Dwpos_Tensorrt"
|
|
||||||
],
|
|
||||||
{
|
|
||||||
"title_aux": "ComfyUI_TensorRT_Merge [WIP]"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"https://github.com/A4P7J1N7M05OT/ComfyUI-ManualSigma": [
|
"https://github.com/A4P7J1N7M05OT/ComfyUI-ManualSigma": [
|
||||||
[
|
[
|
||||||
"ManualSigma"
|
"ManualSigma"
|
||||||
@@ -582,6 +562,16 @@
|
|||||||
"title_aux": "ComfyUI_bd_customNodes"
|
"title_aux": "ComfyUI_bd_customNodes"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/BuffMcBigHuge/ComfyUI-Buff-Nodes": [
|
||||||
|
[
|
||||||
|
"ConsoleOutput",
|
||||||
|
"FilePathSelectorFromDirectory",
|
||||||
|
"StringProcessor"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "ComfyUI-Buff-Nodes [WIP]"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/Chargeuk/ComfyUI-vts-nodes": [
|
"https://github.com/Chargeuk/ComfyUI-vts-nodes": [
|
||||||
[
|
[
|
||||||
"VTS Clean Text",
|
"VTS Clean Text",
|
||||||
@@ -591,6 +581,7 @@
|
|||||||
"VTS Create Character Mask",
|
"VTS Create Character Mask",
|
||||||
"VTS Images Crop From Masks",
|
"VTS Images Crop From Masks",
|
||||||
"VTS Images Scale",
|
"VTS Images Scale",
|
||||||
|
"VTS Images Scale To Min",
|
||||||
"VTS Merge Delimited Text",
|
"VTS Merge Delimited Text",
|
||||||
"VTS Reduce Batch Size",
|
"VTS Reduce Batch Size",
|
||||||
"VTS Render People Kps",
|
"VTS Render People Kps",
|
||||||
@@ -642,7 +633,9 @@
|
|||||||
"DevToolsNodeWithBooleanInput",
|
"DevToolsNodeWithBooleanInput",
|
||||||
"DevToolsNodeWithForceInput",
|
"DevToolsNodeWithForceInput",
|
||||||
"DevToolsNodeWithOnlyOptionalInput",
|
"DevToolsNodeWithOnlyOptionalInput",
|
||||||
|
"DevToolsNodeWithOptionalComboInput",
|
||||||
"DevToolsNodeWithOptionalInput",
|
"DevToolsNodeWithOptionalInput",
|
||||||
|
"DevToolsNodeWithOutputCombo",
|
||||||
"DevToolsNodeWithOutputList",
|
"DevToolsNodeWithOutputList",
|
||||||
"DevToolsNodeWithSeedInput",
|
"DevToolsNodeWithSeedInput",
|
||||||
"DevToolsNodeWithStringInput",
|
"DevToolsNodeWithStringInput",
|
||||||
@@ -809,6 +802,23 @@
|
|||||||
"title_aux": "ComfyUI-MusicGen [WIP]"
|
"title_aux": "ComfyUI-MusicGen [WIP]"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/Elypha/ComfyUI-Prompt-Helper": [
|
||||||
|
[
|
||||||
|
"PromptHelper_CombineConditioning",
|
||||||
|
"PromptHelper_ConcatConditioning",
|
||||||
|
"PromptHelper_ConcatString",
|
||||||
|
"PromptHelper_EncodeMultiStringCombine",
|
||||||
|
"PromptHelper_FormatString",
|
||||||
|
"PromptHelper_LoadPreset",
|
||||||
|
"PromptHelper_LoadPresetAdvanced",
|
||||||
|
"PromptHelper_String",
|
||||||
|
"PromptHelper_StringMultiLine",
|
||||||
|
"PromptHelper_WeightedPrompt"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "ComfyUI-Prompt-Helper [WIP]"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/EmanueleUniroma2/ComfyUI-FLAC-to-WAV": [
|
"https://github.com/EmanueleUniroma2/ComfyUI-FLAC-to-WAV": [
|
||||||
[
|
[
|
||||||
"AudioToWavConverter"
|
"AudioToWavConverter"
|
||||||
@@ -951,19 +961,18 @@
|
|||||||
"title_aux": "comfyui_HavocsCall_Custom_Nodes"
|
"title_aux": "comfyui_HavocsCall_Custom_Nodes"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"https://github.com/HuangYuChuh/ComfyUI-DeepSeek_Toolkit": [
|
"https://github.com/HuangYuChuh/ComfyUI-DeepSeek-Toolkit": [
|
||||||
[
|
[
|
||||||
|
"DeepSeekImageAnalyst",
|
||||||
"DeepSeekImageGeneration",
|
"DeepSeekImageGeneration",
|
||||||
"DeepSeekImageUnderstanding",
|
|
||||||
"DeepSeekModelLoader",
|
"DeepSeekModelLoader",
|
||||||
"GoogleDriveUpload",
|
|
||||||
"ImagePreprocessor",
|
"ImagePreprocessor",
|
||||||
"LLM_Loader",
|
"LLM_Loader",
|
||||||
"OpenAICompatibleLoader",
|
"OpenAICompatibleLoader",
|
||||||
"VideoFileUploader"
|
"VideoFileUploader"
|
||||||
],
|
],
|
||||||
{
|
{
|
||||||
"title_aux": "ComfyUI-DeepSeek_Toolkit [WIP]"
|
"title_aux": "ComfyUI-DeepSeek-Toolkit [WIP]"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"https://github.com/IfnotFr/ComfyUI-Ifnot-Pack": [
|
"https://github.com/IfnotFr/ComfyUI-Ifnot-Pack": [
|
||||||
@@ -1013,44 +1022,6 @@
|
|||||||
"title_aux": "comfyui-terminal-command [UNSAFE]"
|
"title_aux": "comfyui-terminal-command [UNSAFE]"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"https://github.com/JichaoLiang/Immortal_comfyUI": [
|
|
||||||
[
|
|
||||||
"AppendNode",
|
|
||||||
"CombineVideos",
|
|
||||||
"ImAppendFreeChatAction",
|
|
||||||
"ImAppendImageActionNode",
|
|
||||||
"ImAppendNodeHub",
|
|
||||||
"ImAppendQuickbackNode",
|
|
||||||
"ImAppendQuickbackVideoNode",
|
|
||||||
"ImAppendVideoNode",
|
|
||||||
"ImDumpEntity",
|
|
||||||
"ImDumpNode",
|
|
||||||
"ImLoadPackage",
|
|
||||||
"ImNodeTitleOverride",
|
|
||||||
"ImSetActionKeywordMapping",
|
|
||||||
"MergeNode",
|
|
||||||
"Molmo7BDbnbBatch",
|
|
||||||
"MuteNode",
|
|
||||||
"NewNode",
|
|
||||||
"Node2String",
|
|
||||||
"OllamaChat",
|
|
||||||
"SaveImagePath",
|
|
||||||
"SaveToDirectory",
|
|
||||||
"SetEvent",
|
|
||||||
"SetNodeMapping",
|
|
||||||
"SetProperties",
|
|
||||||
"String2Node",
|
|
||||||
"TurnOnOffNodeOnEnter",
|
|
||||||
"batchNodes",
|
|
||||||
"grepNodeByText",
|
|
||||||
"imageList",
|
|
||||||
"mergeEntityAndPointer",
|
|
||||||
"redirectToNode"
|
|
||||||
],
|
|
||||||
{
|
|
||||||
"title_aux": "Immortal_comfyUI"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"https://github.com/Jiffies-64/ComfyUI-SaveImagePlus": [
|
"https://github.com/Jiffies-64/ComfyUI-SaveImagePlus": [
|
||||||
[
|
[
|
||||||
"SaveImagePlus"
|
"SaveImagePlus"
|
||||||
@@ -1155,6 +1126,36 @@
|
|||||||
"title_aux": "RK_Comfyui"
|
"title_aux": "RK_Comfyui"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/KurtHokke/ComfyUI_KurtHokke-Nodes": [
|
||||||
|
[
|
||||||
|
"AIO_Tuner",
|
||||||
|
"AIO_Tuner_Pipe",
|
||||||
|
"BasicAdvScheduler",
|
||||||
|
"Beta_Config",
|
||||||
|
"BooleanFromPipe",
|
||||||
|
"BooleanToPipe",
|
||||||
|
"CkptPipe",
|
||||||
|
"EmptyLatentSize",
|
||||||
|
"EmptyLatentSize64",
|
||||||
|
"ExpMath",
|
||||||
|
"ExpMathDual",
|
||||||
|
"ExpMathQuad",
|
||||||
|
"LMS_Config",
|
||||||
|
"LoadUnetAndClip",
|
||||||
|
"LoraFluxParams",
|
||||||
|
"ModelPipe1",
|
||||||
|
"ModelPipe2",
|
||||||
|
"SamplerCustomAdvanced_Pipe",
|
||||||
|
"SamplerSel",
|
||||||
|
"SchedulerSel",
|
||||||
|
"UnetClipLoraLoader",
|
||||||
|
"UnetClipLoraLoaderBasic",
|
||||||
|
"stopipe"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "ComfyUI_KurtHokke-Nodes"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/LZpenguin/ComfyUI-Text": [
|
"https://github.com/LZpenguin/ComfyUI-Text": [
|
||||||
[
|
[
|
||||||
"Add_text_by_mask"
|
"Add_text_by_mask"
|
||||||
@@ -1200,6 +1201,7 @@
|
|||||||
],
|
],
|
||||||
"https://github.com/LotzF/ComfyUI-Simple-Chat-GPT-completion": [
|
"https://github.com/LotzF/ComfyUI-Simple-Chat-GPT-completion": [
|
||||||
[
|
[
|
||||||
|
"AzureChatGptCompletion",
|
||||||
"ChatGPTCompletion"
|
"ChatGPTCompletion"
|
||||||
],
|
],
|
||||||
{
|
{
|
||||||
@@ -1288,6 +1290,14 @@
|
|||||||
"title_aux": "comfy-tif-support"
|
"title_aux": "comfy-tif-support"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/ManuShamil/ComfyUI_BodyEstimation_Nodes": [
|
||||||
|
[
|
||||||
|
"CogitareLabsPoseIDExtractor"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "ComfyUI_BodyEstimation_Nodes"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/Matrix-King-Studio/ComfyUI-MoviePy": [
|
"https://github.com/Matrix-King-Studio/ComfyUI-MoviePy": [
|
||||||
[
|
[
|
||||||
"AudioDurationNode",
|
"AudioDurationNode",
|
||||||
@@ -1319,6 +1329,41 @@
|
|||||||
"title_aux": "ComfyUI_mickster_nodes [WIP]"
|
"title_aux": "ComfyUI_mickster_nodes [WIP]"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/MockbaTheBorg/ComfyUI-Mockba": [
|
||||||
|
[
|
||||||
|
"mb Barcode",
|
||||||
|
"mb CLIP Text Encoder",
|
||||||
|
"mb Debug",
|
||||||
|
"mb Demux",
|
||||||
|
"mb Empty Latent Image",
|
||||||
|
"mb Eval",
|
||||||
|
"mb Exec",
|
||||||
|
"mb File to Image",
|
||||||
|
"mb File to Text",
|
||||||
|
"mb Hash Generator",
|
||||||
|
"mb Image Batch",
|
||||||
|
"mb Image Dimensions",
|
||||||
|
"mb Image Dither",
|
||||||
|
"mb Image Flip",
|
||||||
|
"mb Image Load",
|
||||||
|
"mb Image Load from URL",
|
||||||
|
"mb Image Preview",
|
||||||
|
"mb Image Rotate",
|
||||||
|
"mb Image Size",
|
||||||
|
"mb Image Subtract",
|
||||||
|
"mb Image to File",
|
||||||
|
"mb KSampler",
|
||||||
|
"mb Select",
|
||||||
|
"mb String",
|
||||||
|
"mb Text",
|
||||||
|
"mb Text or File",
|
||||||
|
"mb Text to File",
|
||||||
|
"mb Textbox"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "ComfyUI-Mockba"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/MrAdamBlack/CheckProgress": [
|
"https://github.com/MrAdamBlack/CheckProgress": [
|
||||||
[
|
[
|
||||||
"CHECK_PROGRESS"
|
"CHECK_PROGRESS"
|
||||||
@@ -1339,19 +1384,28 @@
|
|||||||
[
|
[
|
||||||
"A1111_FLUX_DATA_NODE",
|
"A1111_FLUX_DATA_NODE",
|
||||||
"CategorizeNode",
|
"CategorizeNode",
|
||||||
|
"Data_handle_Node",
|
||||||
|
"DeepSeek_Node",
|
||||||
|
"Delay_node",
|
||||||
|
"DongShowTextNode",
|
||||||
|
"Dong_Pixelate_Node",
|
||||||
|
"Dong_Text_Node",
|
||||||
|
"Downloader",
|
||||||
"FileMoveNode",
|
"FileMoveNode",
|
||||||
"FolderIteratorNODE",
|
"FolderIteratorNODE",
|
||||||
"Get_cookies_Node",
|
"Get_cookies_Node",
|
||||||
"Get_json_value_Node",
|
"Get_json_value_Node",
|
||||||
|
"Get_video_Node",
|
||||||
"HashCalculationsNode",
|
"HashCalculationsNode",
|
||||||
"HuggingFaceUploadNode",
|
"HuggingFaceUploadNode",
|
||||||
|
"IMG2URLNode",
|
||||||
"Image2GIFNode",
|
"Image2GIFNode",
|
||||||
"ImageDownloader",
|
"ImageDownloader",
|
||||||
"InputDetectionNode",
|
"ImageResizeNode",
|
||||||
"LLM_Node",
|
|
||||||
"LibLib_upload_Node",
|
"LibLib_upload_Node",
|
||||||
"LogicToolsNode",
|
"LogicToolsNode",
|
||||||
"LoraIterator",
|
"LoraIterator",
|
||||||
|
"PromptConcatNode",
|
||||||
"RandomNumbersNode",
|
"RandomNumbersNode",
|
||||||
"RenameNode",
|
"RenameNode",
|
||||||
"ResolutionNode",
|
"ResolutionNode",
|
||||||
@@ -1360,7 +1414,10 @@
|
|||||||
"TextToJsonNode",
|
"TextToJsonNode",
|
||||||
"TranslateAPINode",
|
"TranslateAPINode",
|
||||||
"ZIPwith7zNode",
|
"ZIPwith7zNode",
|
||||||
|
"img_understanding_Node",
|
||||||
|
"klingai_video_Node",
|
||||||
"path_join_Node",
|
"path_join_Node",
|
||||||
|
"save_img_NODE",
|
||||||
"set_api_Node"
|
"set_api_Node"
|
||||||
],
|
],
|
||||||
{
|
{
|
||||||
@@ -1369,14 +1426,23 @@
|
|||||||
],
|
],
|
||||||
"https://github.com/Northerner1/ComfyUI_North_Noise": [
|
"https://github.com/Northerner1/ComfyUI_North_Noise": [
|
||||||
[
|
[
|
||||||
"North_Unsampler"
|
"North_Noise"
|
||||||
],
|
],
|
||||||
{
|
{
|
||||||
"title_aux": "ComfyUI_North_Noise [WIP]"
|
"title_aux": "ComfyUI_North_Noise [WIP]"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/OSAnimate/ComfyUI-SpriteSheetMaker": [
|
||||||
|
[
|
||||||
|
"SpriteSheetMaker"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "ComfyUI-SpriteSheetMaker [WIP]"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/PATATAJEC/Patatajec-Nodes": [
|
"https://github.com/PATATAJEC/Patatajec-Nodes": [
|
||||||
[
|
[
|
||||||
|
"FilePrefixSwitcher",
|
||||||
"HyvidSwitcher",
|
"HyvidSwitcher",
|
||||||
"ImageSequenceFromBatch",
|
"ImageSequenceFromBatch",
|
||||||
"MidiReader",
|
"MidiReader",
|
||||||
@@ -1388,6 +1454,14 @@
|
|||||||
"title_aux": "Patatajec-Nodes [WIP]"
|
"title_aux": "Patatajec-Nodes [WIP]"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/Pablerdo/ComfyUI-Sa2VAWrapper": [
|
||||||
|
[
|
||||||
|
"GetCaptionFromImages"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "ComfyUI-Sa2VAWrapper"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/PluMaZero/ComfyUI-SpaceFlower": [
|
"https://github.com/PluMaZero/ComfyUI-SpaceFlower": [
|
||||||
[
|
[
|
||||||
"SpaceFlower_HangulPrompt",
|
"SpaceFlower_HangulPrompt",
|
||||||
@@ -1466,39 +1540,12 @@
|
|||||||
"title_aux": "comfyui-promptbymood [WIP]"
|
"title_aux": "comfyui-promptbymood [WIP]"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"https://github.com/RiceRound/ComfyUI_RiceRound": [
|
"https://github.com/RUFFY-369/ComfyUI-FeatureBank": [
|
||||||
[
|
[
|
||||||
"RiceRoundAdvancedChoiceNode",
|
"FeatureBankAttentionProcessor"
|
||||||
"RiceRoundBooleanNode",
|
|
||||||
"RiceRoundDecryptNode",
|
|
||||||
"RiceRoundDownloadImageAndMaskNode",
|
|
||||||
"RiceRoundDownloadImageNode",
|
|
||||||
"RiceRoundDownloadMaskNode",
|
|
||||||
"RiceRoundEncryptNode",
|
|
||||||
"RiceRoundFloatNode",
|
|
||||||
"RiceRoundImageBridgeNode",
|
|
||||||
"RiceRoundImageNode",
|
|
||||||
"RiceRoundImageUrlNode",
|
|
||||||
"RiceRoundInputTextNode",
|
|
||||||
"RiceRoundIntNode",
|
|
||||||
"RiceRoundMaskBridgeNode",
|
|
||||||
"RiceRoundOutputBooleanNode",
|
|
||||||
"RiceRoundOutputFloatNode",
|
|
||||||
"RiceRoundOutputImageBridgeNode",
|
|
||||||
"RiceRoundOutputImageNode",
|
|
||||||
"RiceRoundOutputIntNode",
|
|
||||||
"RiceRoundOutputMaskBridgeNode",
|
|
||||||
"RiceRoundOutputTextNode",
|
|
||||||
"RiceRoundRandomSeedNode",
|
|
||||||
"RiceRoundSimpleChoiceNode",
|
|
||||||
"RiceRoundSimpleImageNode",
|
|
||||||
"RiceRoundStrToBooleanNode",
|
|
||||||
"RiceRoundStrToFloatNode",
|
|
||||||
"RiceRoundStrToIntNode",
|
|
||||||
"RiceRoundUploadImageNode"
|
|
||||||
],
|
],
|
||||||
{
|
{
|
||||||
"title_aux": "RiceRound Cloud Node [UNSAFE]"
|
"title_aux": "ComfyUI-FeatureBank"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"https://github.com/RicherdLee/comfyui-oss-image-save": [
|
"https://github.com/RicherdLee/comfyui-oss-image-save": [
|
||||||
@@ -1522,6 +1569,22 @@
|
|||||||
"title_aux": "Comfy UI Robe Nodes [UNSAFE]"
|
"title_aux": "Comfy UI Robe Nodes [UNSAFE]"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/RoyKillington/miscomfy-nodes": [
|
||||||
|
[
|
||||||
|
"VeniceUpscale"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "Miscomfy Nodes [WIP]"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"https://github.com/S4MUEL-404/ComfyUI-Folder-Images-Preview": [
|
||||||
|
[
|
||||||
|
"FolderImagesPreview"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "ComfyUI-Folder-Images-Preview [UNSAFE]"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/SS-snap/ComfyUI-Snap_Processing": [
|
"https://github.com/SS-snap/ComfyUI-Snap_Processing": [
|
||||||
[
|
[
|
||||||
"AreaCalculator",
|
"AreaCalculator",
|
||||||
@@ -1585,7 +1648,9 @@
|
|||||||
"CheckpointLoaderSimpleShared //SeedV",
|
"CheckpointLoaderSimpleShared //SeedV",
|
||||||
"ControlNetLoaderAdvancedShared",
|
"ControlNetLoaderAdvancedShared",
|
||||||
"LoraLoader //SeedV",
|
"LoraLoader //SeedV",
|
||||||
"Script"
|
"Script",
|
||||||
|
"Switch_Any(SEEDV)",
|
||||||
|
"TCD_Sampler(SEEDV)"
|
||||||
],
|
],
|
||||||
{
|
{
|
||||||
"title_aux": "ComfyUI-SeedV-Nodes [UNSAFE]"
|
"title_aux": "ComfyUI-SeedV-Nodes [UNSAFE]"
|
||||||
@@ -1746,6 +1811,16 @@
|
|||||||
"title_aux": "Comfyui_leffa"
|
"title_aux": "Comfyui_leffa"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/StoryWalker/comfyui_flux_collection_advanced": [
|
||||||
|
[
|
||||||
|
"Example",
|
||||||
|
"FluxImageUpscaler",
|
||||||
|
"FluxLoader"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "comfyui_flux_collection_advanced [WIP]"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/TSFSean/ComfyUI-TSFNodes": [
|
"https://github.com/TSFSean/ComfyUI-TSFNodes": [
|
||||||
[
|
[
|
||||||
"GyroOSC"
|
"GyroOSC"
|
||||||
@@ -1884,6 +1959,15 @@
|
|||||||
"title_aux": "ComfyUI-PuLID-ZHO [WIP]"
|
"title_aux": "ComfyUI-PuLID-ZHO [WIP]"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/ZHO-ZHO-ZHO/ComfyUI-Wan-ZHO": [
|
||||||
|
[
|
||||||
|
"WanT2V_Generation_Zho",
|
||||||
|
"WanT2V_ModelLoader_Zho"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "ComfyUI Wan2.1 [WIP]"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/a-One-Fan/ComfyUI-Blenderesque-Nodes": [
|
"https://github.com/a-One-Fan/ComfyUI-Blenderesque-Nodes": [
|
||||||
[
|
[
|
||||||
"BlenderAlphaConvert",
|
"BlenderAlphaConvert",
|
||||||
@@ -2060,6 +2144,14 @@
|
|||||||
"title_aux": "ComfyUI-SkipCFGSigmas"
|
"title_aux": "ComfyUI-SkipCFGSigmas"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/aria1th/ComfyUI-camietagger-onnx": [
|
||||||
|
[
|
||||||
|
"CamieTagger"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "ComfyUI-camietagger-onnx"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/artem-konevskikh/comfyui-split-merge-video": [
|
"https://github.com/artem-konevskikh/comfyui-split-merge-video": [
|
||||||
[
|
[
|
||||||
"VideoMerger",
|
"VideoMerger",
|
||||||
@@ -2503,6 +2595,7 @@
|
|||||||
"ConditioningConcat",
|
"ConditioningConcat",
|
||||||
"ConditioningSetArea",
|
"ConditioningSetArea",
|
||||||
"ConditioningSetAreaPercentage",
|
"ConditioningSetAreaPercentage",
|
||||||
|
"ConditioningSetAreaPercentageVideo",
|
||||||
"ConditioningSetAreaStrength",
|
"ConditioningSetAreaStrength",
|
||||||
"ConditioningSetMask",
|
"ConditioningSetMask",
|
||||||
"ConditioningSetTimestepRange",
|
"ConditioningSetTimestepRange",
|
||||||
@@ -2540,6 +2633,7 @@
|
|||||||
"GLIGENLoader",
|
"GLIGENLoader",
|
||||||
"GLIGENTextBoxApply",
|
"GLIGENTextBoxApply",
|
||||||
"GrowMask",
|
"GrowMask",
|
||||||
|
"HunyuanImageToVideo",
|
||||||
"HyperTile",
|
"HyperTile",
|
||||||
"HypernetworkLoader",
|
"HypernetworkLoader",
|
||||||
"ImageBatch",
|
"ImageBatch",
|
||||||
@@ -2568,8 +2662,11 @@
|
|||||||
"KSamplerAdvanced",
|
"KSamplerAdvanced",
|
||||||
"KSamplerSelect",
|
"KSamplerSelect",
|
||||||
"KarrasScheduler",
|
"KarrasScheduler",
|
||||||
|
"LTXVAddGuide",
|
||||||
"LTXVConditioning",
|
"LTXVConditioning",
|
||||||
|
"LTXVCropGuides",
|
||||||
"LTXVImgToVideo",
|
"LTXVImgToVideo",
|
||||||
|
"LTXVPreprocess",
|
||||||
"LTXVScheduler",
|
"LTXVScheduler",
|
||||||
"LaplaceScheduler",
|
"LaplaceScheduler",
|
||||||
"LatentAdd",
|
"LatentAdd",
|
||||||
@@ -2726,6 +2823,7 @@
|
|||||||
"TestVariadicAverage",
|
"TestVariadicAverage",
|
||||||
"TestWhileLoopClose",
|
"TestWhileLoopClose",
|
||||||
"TestWhileLoopOpen",
|
"TestWhileLoopOpen",
|
||||||
|
"TextEncodeHunyuanVideo_ImageToVideo",
|
||||||
"ThresholdMask",
|
"ThresholdMask",
|
||||||
"TomePatchModel",
|
"TomePatchModel",
|
||||||
"TorchCompileModel",
|
"TorchCompileModel",
|
||||||
@@ -2747,6 +2845,7 @@
|
|||||||
"VPScheduler",
|
"VPScheduler",
|
||||||
"VideoLinearCFGGuidance",
|
"VideoLinearCFGGuidance",
|
||||||
"VideoTriangleCFGGuidance",
|
"VideoTriangleCFGGuidance",
|
||||||
|
"WanImageToVideo",
|
||||||
"WebcamCapture",
|
"WebcamCapture",
|
||||||
"unCLIPCheckpointLoader",
|
"unCLIPCheckpointLoader",
|
||||||
"unCLIPConditioning"
|
"unCLIPConditioning"
|
||||||
@@ -3015,10 +3114,12 @@
|
|||||||
"https://github.com/fablestudio/ComfyUI-Showrunner-Utils": [
|
"https://github.com/fablestudio/ComfyUI-Showrunner-Utils": [
|
||||||
[
|
[
|
||||||
"AlignFace",
|
"AlignFace",
|
||||||
|
"Alpha Crop and Position Image",
|
||||||
"GenerateTimestamp",
|
"GenerateTimestamp",
|
||||||
"GetMostCommonColors",
|
"GetMostCommonColors",
|
||||||
"ReadImage",
|
"ReadImage",
|
||||||
"RenderOpenStreetMapTile"
|
"RenderOpenStreetMapTile",
|
||||||
|
"Shrink Image"
|
||||||
],
|
],
|
||||||
{
|
{
|
||||||
"title_aux": "ComfyUI-Showrunner-Utils"
|
"title_aux": "ComfyUI-Showrunner-Utils"
|
||||||
@@ -3163,9 +3264,22 @@
|
|||||||
"https://github.com/grinlau18/ComfyUI_XISER_Nodes": [
|
"https://github.com/grinlau18/ComfyUI_XISER_Nodes": [
|
||||||
[
|
[
|
||||||
"XIS_Float_Slider",
|
"XIS_Float_Slider",
|
||||||
|
"XIS_FromListGet1Color",
|
||||||
|
"XIS_FromListGet1Cond",
|
||||||
|
"XIS_FromListGet1Float",
|
||||||
|
"XIS_FromListGet1Image",
|
||||||
|
"XIS_FromListGet1Int",
|
||||||
|
"XIS_FromListGet1Latent",
|
||||||
|
"XIS_FromListGet1Mask",
|
||||||
|
"XIS_FromListGet1Model",
|
||||||
|
"XIS_FromListGet1String",
|
||||||
"XIS_INT_Slider",
|
"XIS_INT_Slider",
|
||||||
|
"XIS_ImageMaskMirror",
|
||||||
|
"XIS_InvertMask",
|
||||||
|
"XIS_IsThereAnyData",
|
||||||
"XIS_PromptsWithSwitches",
|
"XIS_PromptsWithSwitches",
|
||||||
"XIS_ResizeImageOrMask"
|
"XIS_ResizeImageOrMask",
|
||||||
|
"XIS_ResizeToDivisible"
|
||||||
],
|
],
|
||||||
{
|
{
|
||||||
"title_aux": "Xiser_Nodes [WIP]"
|
"title_aux": "Xiser_Nodes [WIP]"
|
||||||
@@ -3220,13 +3334,14 @@
|
|||||||
"ACE_ImageFaceCrop",
|
"ACE_ImageFaceCrop",
|
||||||
"ACE_ImageGetSize",
|
"ACE_ImageGetSize",
|
||||||
"ACE_ImageLoadFromCloud",
|
"ACE_ImageLoadFromCloud",
|
||||||
"ACE_ImageMakeSlieshow",
|
"ACE_ImageMakeSlideshow",
|
||||||
"ACE_ImagePixelate",
|
"ACE_ImagePixelate",
|
||||||
"ACE_ImageQA",
|
"ACE_ImageQA",
|
||||||
"ACE_ImageRemoveBackground",
|
"ACE_ImageRemoveBackground",
|
||||||
"ACE_ImageSaveToCloud",
|
"ACE_ImageSaveToCloud",
|
||||||
"ACE_Integer",
|
"ACE_Integer",
|
||||||
"ACE_MaskBlur",
|
"ACE_MaskBlur",
|
||||||
|
"ACE_OpenAI_GPT_Chat",
|
||||||
"ACE_Seed",
|
"ACE_Seed",
|
||||||
"ACE_Text",
|
"ACE_Text",
|
||||||
"ACE_TextConcatenate",
|
"ACE_TextConcatenate",
|
||||||
@@ -3235,7 +3350,9 @@
|
|||||||
"ACE_TextInputSwitch4Way",
|
"ACE_TextInputSwitch4Way",
|
||||||
"ACE_TextInputSwitch8Way",
|
"ACE_TextInputSwitch8Way",
|
||||||
"ACE_TextList",
|
"ACE_TextList",
|
||||||
|
"ACE_TextLoad",
|
||||||
"ACE_TextPreview",
|
"ACE_TextPreview",
|
||||||
|
"ACE_TextSave",
|
||||||
"ACE_TextSelector",
|
"ACE_TextSelector",
|
||||||
"ACE_TextToResolution",
|
"ACE_TextToResolution",
|
||||||
"ACE_TextTranslate",
|
"ACE_TextTranslate",
|
||||||
@@ -3481,6 +3598,27 @@
|
|||||||
"title_aux": "ComfyUI PaintingCoderUtils Nodes [WIP]"
|
"title_aux": "ComfyUI PaintingCoderUtils Nodes [WIP]"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/jcomeme/ComfyUI-AsunaroTools": [
|
||||||
|
[
|
||||||
|
"AsunaroAnd",
|
||||||
|
"AsunaroAutomaticSexPrompter",
|
||||||
|
"AsunaroBatchImageLoader",
|
||||||
|
"AsunaroIfBiggerThanZero",
|
||||||
|
"AsunaroIfContain",
|
||||||
|
"AsunaroIfSame",
|
||||||
|
"AsunaroImageLoader",
|
||||||
|
"AsunaroIntToStr",
|
||||||
|
"AsunaroOr",
|
||||||
|
"AsunaroPromptStripper",
|
||||||
|
"AsunaroRandomDice",
|
||||||
|
"AsunaroSave",
|
||||||
|
"AsunaroTextConcatenator",
|
||||||
|
"AsunaroWildCard"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "AsunaroTools"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/jgbrblmd/ComfyUI-ComfyFluxSize": [
|
"https://github.com/jgbrblmd/ComfyUI-ComfyFluxSize": [
|
||||||
[
|
[
|
||||||
"ComfyFluxSize"
|
"ComfyFluxSize"
|
||||||
@@ -3672,15 +3810,11 @@
|
|||||||
],
|
],
|
||||||
"https://github.com/kandy/ComfyUI-KAndy": [
|
"https://github.com/kandy/ComfyUI-KAndy": [
|
||||||
[
|
[
|
||||||
"KAndyBatch2Index",
|
|
||||||
"KAndyBatchIndex",
|
|
||||||
"KAndyCivitImagesAPI",
|
"KAndyCivitImagesAPI",
|
||||||
"KAndyCivitPromptAPI",
|
"KAndyCivitPromptAPI",
|
||||||
"KAndyImageSave",
|
|
||||||
"KAndyImagesByCss",
|
"KAndyImagesByCss",
|
||||||
"KAndyLoadImageFromUrl",
|
"KAndyLoadImageFromUrl",
|
||||||
"KAndyNoiseCondition",
|
"KAndyNoiseCondition",
|
||||||
"KCivitaiPostAPI",
|
|
||||||
"KPornImageAPI",
|
"KPornImageAPI",
|
||||||
"KPromtGen",
|
"KPromtGen",
|
||||||
"KandySimplePrompt"
|
"KandySimplePrompt"
|
||||||
@@ -3820,7 +3954,10 @@
|
|||||||
"HyVideoDecode",
|
"HyVideoDecode",
|
||||||
"HyVideoEmptyTextEmbeds",
|
"HyVideoEmptyTextEmbeds",
|
||||||
"HyVideoEncode",
|
"HyVideoEncode",
|
||||||
|
"HyVideoEncodeKeyframes",
|
||||||
"HyVideoEnhanceAVideo",
|
"HyVideoEnhanceAVideo",
|
||||||
|
"HyVideoGetClosestBucketSize",
|
||||||
|
"HyVideoI2VEncode",
|
||||||
"HyVideoInverseSampler",
|
"HyVideoInverseSampler",
|
||||||
"HyVideoLatentPreview",
|
"HyVideoLatentPreview",
|
||||||
"HyVideoLoraBlockEdit",
|
"HyVideoLoraBlockEdit",
|
||||||
@@ -3894,6 +4031,34 @@
|
|||||||
"title_aux": "ComfyUI-VideoNoiseWarp [WIP]"
|
"title_aux": "ComfyUI-VideoNoiseWarp [WIP]"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/kijai/ComfyUI-WanVideoWrapper": [
|
||||||
|
[
|
||||||
|
"LoadWanVideoClipTextEncoder",
|
||||||
|
"LoadWanVideoT5TextEncoder",
|
||||||
|
"WanVideoBlockSwap",
|
||||||
|
"WanVideoContextOptions",
|
||||||
|
"WanVideoDecode",
|
||||||
|
"WanVideoEmptyEmbeds",
|
||||||
|
"WanVideoEncode",
|
||||||
|
"WanVideoEnhanceAVideo",
|
||||||
|
"WanVideoFlowEdit",
|
||||||
|
"WanVideoImageClipEncode",
|
||||||
|
"WanVideoLatentPreview",
|
||||||
|
"WanVideoLoraBlockEdit",
|
||||||
|
"WanVideoLoraSelect",
|
||||||
|
"WanVideoModelLoader",
|
||||||
|
"WanVideoSampler",
|
||||||
|
"WanVideoTeaCache",
|
||||||
|
"WanVideoTextEmbedBridge",
|
||||||
|
"WanVideoTextEncode",
|
||||||
|
"WanVideoTorchCompileSettings",
|
||||||
|
"WanVideoVAELoader",
|
||||||
|
"WanVideoVRAMManagement"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "ComfyUI-WanVideoWrapper [WIP]"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/kimara-ai/ComfyUI-Kimara-AI-Advanced-Watermarks": [
|
"https://github.com/kimara-ai/ComfyUI-Kimara-AI-Advanced-Watermarks": [
|
||||||
[
|
[
|
||||||
"KimaraAIBatchImages",
|
"KimaraAIBatchImages",
|
||||||
@@ -3913,14 +4078,27 @@
|
|||||||
],
|
],
|
||||||
"https://github.com/kk8bit/KayTool": [
|
"https://github.com/kk8bit/KayTool": [
|
||||||
[
|
[
|
||||||
|
"AB_Images",
|
||||||
|
"AIO_Translater",
|
||||||
"Abc_Math",
|
"Abc_Math",
|
||||||
"Baidu_Translater",
|
"Baidu_Translater",
|
||||||
|
"BiRefNet_Loader",
|
||||||
"Color_Adjustment",
|
"Color_Adjustment",
|
||||||
"Custom_Save_Image",
|
"Custom_Save_Image",
|
||||||
"Display_Any",
|
"Display_Any",
|
||||||
"Image_Size_Extractor",
|
"Image_Size_Extractor",
|
||||||
|
"Mask_Blur_Plus",
|
||||||
|
"Preview_Mask",
|
||||||
|
"Preview_Mask_Plus",
|
||||||
|
"RemBG_Loader",
|
||||||
|
"Remove_BG",
|
||||||
|
"Slider_10",
|
||||||
|
"Slider_100",
|
||||||
|
"Slider_1000",
|
||||||
"Strong_Prompt",
|
"Strong_Prompt",
|
||||||
"Tencent_Translater"
|
"Tencent_Translater",
|
||||||
|
"Text",
|
||||||
|
"To_Int"
|
||||||
],
|
],
|
||||||
{
|
{
|
||||||
"title_aux": "KayTool"
|
"title_aux": "KayTool"
|
||||||
@@ -4176,6 +4354,14 @@
|
|||||||
"title_aux": "comfyui-one-more-step [WIP]"
|
"title_aux": "comfyui-one-more-step [WIP]"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/longzoho/ComfyUI-Qdrant-Saver": [
|
||||||
|
[
|
||||||
|
"QDrantSaver"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "ComfyUI-Qdrant-Saver"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/lordwedggie/xcpNodes": [
|
"https://github.com/lordwedggie/xcpNodes": [
|
||||||
[
|
[
|
||||||
"derpBaseAlpha",
|
"derpBaseAlpha",
|
||||||
@@ -4230,10 +4416,11 @@
|
|||||||
],
|
],
|
||||||
"https://github.com/lum3on/comfyui_LLM_Polymath": [
|
"https://github.com/lum3on/comfyui_LLM_Polymath": [
|
||||||
[
|
[
|
||||||
"Helper",
|
"ConceptEraserNode",
|
||||||
"UCEEraserNode",
|
|
||||||
"polymath_SaveAbsolute",
|
"polymath_SaveAbsolute",
|
||||||
"polymath_chat",
|
"polymath_chat",
|
||||||
|
"polymath_concept_eraser",
|
||||||
|
"polymath_helper",
|
||||||
"polymath_scraper"
|
"polymath_scraper"
|
||||||
],
|
],
|
||||||
{
|
{
|
||||||
@@ -4636,16 +4823,39 @@
|
|||||||
],
|
],
|
||||||
"https://github.com/nomcycle/ComfyUI_Cluster": [
|
"https://github.com/nomcycle/ComfyUI_Cluster": [
|
||||||
[
|
[
|
||||||
"ClusterFanInImages",
|
"ClusterBroadcastLoadedImage",
|
||||||
"ClusterFanInLatents",
|
"ClusterBroadcastTensor",
|
||||||
"ClusterInstanceIndex"
|
"ClusterExecuteCurrentWorkflow",
|
||||||
|
"ClusterExecuteWorkflow",
|
||||||
|
"ClusterFanOutImage",
|
||||||
|
"ClusterFanOutLatent",
|
||||||
|
"ClusterFanOutMask",
|
||||||
|
"ClusterGatherImages",
|
||||||
|
"ClusterGatherLatents",
|
||||||
|
"ClusterGatherMasks",
|
||||||
|
"ClusterGetInstanceWorkItemFromBatch",
|
||||||
|
"ClusterInfo",
|
||||||
|
"ClusterListenTensorBroadcast"
|
||||||
],
|
],
|
||||||
{
|
{
|
||||||
"title_aux": "ComfyUI_Cluster [WIP]"
|
"title_aux": "ComfyUI_Cluster [WIP]"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/nova-florealis/comfyui-alien": [
|
||||||
|
[
|
||||||
|
"ConvertMarkdown",
|
||||||
|
"ListDisplayNode",
|
||||||
|
"MarkdownConverterModule",
|
||||||
|
"TextOutput",
|
||||||
|
"TextToText"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "comfyui-alien"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/oshtz/ComfyUI-oshtz-nodes": [
|
"https://github.com/oshtz/ComfyUI-oshtz-nodes": [
|
||||||
[
|
[
|
||||||
|
"EasyAspectRatioNode",
|
||||||
"ImageOverlayNode",
|
"ImageOverlayNode",
|
||||||
"LLMAIONode",
|
"LLMAIONode",
|
||||||
"LoRASwitcherNode",
|
"LoRASwitcherNode",
|
||||||
@@ -4726,6 +4936,7 @@
|
|||||||
"LatentToWidthHeight",
|
"LatentToWidthHeight",
|
||||||
"MaskCompositePPM",
|
"MaskCompositePPM",
|
||||||
"PPMSamplerSelect",
|
"PPMSamplerSelect",
|
||||||
|
"RenormCFGPost",
|
||||||
"RescaleCFGPost"
|
"RescaleCFGPost"
|
||||||
],
|
],
|
||||||
{
|
{
|
||||||
@@ -4780,6 +4991,14 @@
|
|||||||
"title_aux": "ComyUI-Tupham"
|
"title_aux": "ComyUI-Tupham"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/pixuai/ComfyUI-PixuAI": [
|
||||||
|
[
|
||||||
|
"PromptSearch"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "ComfyUI-PixuAI"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/poisenbery/NudeNet-Detector-Provider": [
|
"https://github.com/poisenbery/NudeNet-Detector-Provider": [
|
||||||
[
|
[
|
||||||
"NudeNetDetectorProvider"
|
"NudeNetDetectorProvider"
|
||||||
@@ -4894,6 +5113,14 @@
|
|||||||
"title_aux": "ComfyUI_HEXtoRGB"
|
"title_aux": "ComfyUI_HEXtoRGB"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/ritikvirus/comfyui-terminal-modal-node": [
|
||||||
|
[
|
||||||
|
"terminal_node"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "ComfyUI Terminal Command Node [UNSAFE]"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/rouxianmantou/comfyui-rxmt-nodes": [
|
"https://github.com/rouxianmantou/comfyui-rxmt-nodes": [
|
||||||
[
|
[
|
||||||
"CheckValueTypeNode",
|
"CheckValueTypeNode",
|
||||||
@@ -4920,14 +5147,6 @@
|
|||||||
"title_aux": "ComfyUI_YoloNasObjectDetection_Tensorrt [WIP]"
|
"title_aux": "ComfyUI_YoloNasObjectDetection_Tensorrt [WIP]"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"https://github.com/scottmudge/ComfyUI_BiscuitNodes": [
|
|
||||||
[
|
|
||||||
"LoadImagePrompted"
|
|
||||||
],
|
|
||||||
{
|
|
||||||
"title_aux": "ComfyUI_BiscuitNodes"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"https://github.com/sdfxai/SDFXBridgeForComfyUI": [
|
"https://github.com/sdfxai/SDFXBridgeForComfyUI": [
|
||||||
[
|
[
|
||||||
"SDFXClipTextEncode"
|
"SDFXClipTextEncode"
|
||||||
@@ -5185,6 +5404,15 @@
|
|||||||
"title_aux": "ComfyUI_Save_Flux_Image"
|
"title_aux": "ComfyUI_Save_Flux_Image"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/techidsk/comfyui_molook_nodes": [
|
||||||
|
[
|
||||||
|
"MaskExpand(Molook)",
|
||||||
|
"OpenAIProvider(Molook)"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "comfyui_molook_nodes [WIP]"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/techzuhaib/ComfyUI-CacheImageNode": [
|
"https://github.com/techzuhaib/ComfyUI-CacheImageNode": [
|
||||||
[
|
[
|
||||||
"CacheImageNode"
|
"CacheImageNode"
|
||||||
@@ -5446,6 +5674,32 @@
|
|||||||
"title_aux": "CombineMasksNode"
|
"title_aux": "CombineMasksNode"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/xmarked-ai/ComfyUI_misc": [
|
||||||
|
[
|
||||||
|
"AceColorFixX",
|
||||||
|
"AceFloatX",
|
||||||
|
"AceIntegerX",
|
||||||
|
"CheckpointLoaderBNB_X",
|
||||||
|
"CheckpointLoaderNF4_X",
|
||||||
|
"DepthDisplaceX",
|
||||||
|
"EmptyLatentX",
|
||||||
|
"IfConditionX",
|
||||||
|
"ImageTileSquare",
|
||||||
|
"ImageUntileSquare",
|
||||||
|
"KSamplerComboX",
|
||||||
|
"LoopCloseX",
|
||||||
|
"LoopOpenX",
|
||||||
|
"LoraBatchSamplerX",
|
||||||
|
"RelightX",
|
||||||
|
"RemoveBackgroundX",
|
||||||
|
"SelectiveDepthLoraBlocksX",
|
||||||
|
"UnetLoaderBNB_X",
|
||||||
|
"WhiteBalanceX"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "ComfyUI_misc"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/yanhuifair/ComfyUI-FairLab": [
|
"https://github.com/yanhuifair/ComfyUI-FairLab": [
|
||||||
[
|
[
|
||||||
"CLIPTranslatedNode",
|
"CLIPTranslatedNode",
|
||||||
@@ -5529,6 +5783,14 @@
|
|||||||
"title_aux": "Comfyui_image2prompt"
|
"title_aux": "Comfyui_image2prompt"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/zjkhurry/comfyui_MetalFX": [
|
||||||
|
[
|
||||||
|
"metalFXImg"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "comfyui_MetalFX [WIP]"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/zyd232/ComfyUI-zyd232-Nodes": [
|
"https://github.com/zyd232/ComfyUI-zyd232-Nodes": [
|
||||||
[
|
[
|
||||||
"zyd232 ImagesPixelsCompare",
|
"zyd232 ImagesPixelsCompare",
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -11,6 +11,86 @@
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
{
|
||||||
|
"author": "Samulebotin",
|
||||||
|
"title": "ComfyUI-FreeVC_wrapper [REMOVED]",
|
||||||
|
"reference": "https://github.com/Samulebotin/ComfyUI-FreeVC_wrapper",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/Samulebotin/ComfyUI-FreeVC_wrapper"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A voice conversion extension node for ComfyUI based on FreeVC, enabling high-quality voice conversion capabilities within the ComfyUI framework."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "GoingAI1998",
|
||||||
|
"title": "ComfyUI Web Canvas Node [REMOVED]",
|
||||||
|
"reference": "https://github.com/GoingAI1998/Comfyui_imgcanvas",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/GoingAI1998/Comfyui_imgcanvas"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "ComfyUI_imgcanvas At present, I have not used the useful comfyui custom node about layer mixing, and I have written a comfyui runtime automatic pop-up window for layer editing node"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "807502278",
|
||||||
|
"title": "ComfyUI_TensorRT_Merge [REMOVED]",
|
||||||
|
"reference": "https://github.com/807502278/ComfyUI_TensorRT_Merge",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/807502278/ComfyUI_TensorRT_Merge"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Non diffusion models supported by TensorRT, merged Comfyui plugin, added onnx automatic download and trt model conversion nodes."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "logtd",
|
||||||
|
"title": "ComfyUI-LTXTricks [DEPRECATED]",
|
||||||
|
"reference": "https://github.com/logtd/ComfyUI-LTXTricks",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/logtd/ComfyUI-LTXTricks"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A set of nodes that provide additional controls for the LTX Video model"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "JichaoLiang",
|
||||||
|
"title": "Immortal_comfyUI [REMOVED]",
|
||||||
|
"reference": "https://github.com/JichaoLiang/Immortal_comfyUI",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/JichaoLiang/Immortal_comfyUI"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "NODES:ImNewNode, ImAppendNode, MergeNode, SetProperties, SaveToDirectory, batchNodes, redirectToNode, SetEvent, ..."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "Rvage0815",
|
||||||
|
"title": "ComfyUI-RvTools [REMOVED]",
|
||||||
|
"reference": "https://github.com/Rvage0815/ComfyUI-RvTools",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/Rvage0815/ComfyUI-RvTools"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "this node contains a lot of small little helpers like switches, passers and selectors that i use a lot to build my workflows."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "Rvage0815",
|
||||||
|
"title": "RvTComfyUI-RvTools_v2 [REMOVED]",
|
||||||
|
"reference": "https://github.com/Rvage0815/ComfyUI-RvTools_v2",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/Rvage0815/ComfyUI-RvTools_v2"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "this node contains a lot of small little helpers like switches, passers and selectors that i use a lot to build my workflows."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "scottmudge",
|
||||||
|
"title": "ComfyUI_BiscuitNodes [REMOVED]",
|
||||||
|
"reference": "https://github.com/scottmudge/ComfyUI_BiscuitNodes",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/scottmudge/ComfyUI_BiscuitNodes"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Load Image From Path Using File Selector"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"author": "thanhduong0213929",
|
"author": "thanhduong0213929",
|
||||||
"title": "ComfyUI-DeepUnlock [REMOVED]",
|
"title": "ComfyUI-DeepUnlock [REMOVED]",
|
||||||
@@ -115,7 +195,7 @@
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
"author": "myAiLemon",
|
"author": "myAiLemon",
|
||||||
"title": "MagicGetPromptAutomatically",
|
"title": "MagicGetPromptAutomatically [REMOVED]",
|
||||||
"reference": "https://github.com/myAiLemon/MagicGetPromptAutomatically",
|
"reference": "https://github.com/myAiLemon/MagicGetPromptAutomatically",
|
||||||
"files": [
|
"files": [
|
||||||
"https://github.com/myAiLemon/MagicGetPromptAutomatically"
|
"https://github.com/myAiLemon/MagicGetPromptAutomatically"
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@@ -1,5 +1,39 @@
|
|||||||
{
|
{
|
||||||
"models": [
|
"models": [
|
||||||
|
{
|
||||||
|
"name": "Comfy-Org/hunyuan_video_image_to_video_720p_bf16.safetensors",
|
||||||
|
"type": "diffusion_model",
|
||||||
|
"base": "Hunyuan Video",
|
||||||
|
"save_path": "diffusion_models/hunyuan_video",
|
||||||
|
"description": "Huyuan Video Image2Video diffusion model. repackaged version.",
|
||||||
|
"reference": "https://huggingface.co/Comfy-Org/HunyuanVideo_repackaged",
|
||||||
|
"filename": "hunyuan_video_image_to_video_720p_bf16.safetensors",
|
||||||
|
"url": "https://huggingface.co/Comfy-Org/HunyuanVideo_repackaged/resolve/main/split_files/diffusion_models/hunyuan_video_image_to_video_720p_bf16.safetensors",
|
||||||
|
"size": "25.6GB"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "Comfy-Org/llava_llama3_vision.safetensors",
|
||||||
|
"type": "clip_vision",
|
||||||
|
"base": "LLaVA-Llama-3",
|
||||||
|
"save_path": "text_encoders",
|
||||||
|
"description": "llava_llama3_vision clip vison model. This is required for using Hunyuan Video Image2Video.",
|
||||||
|
"reference": "https://huggingface.co/Comfy-Org/HunyuanVideo_repackaged",
|
||||||
|
"filename": "llava_llama3_vision.safetensors",
|
||||||
|
"url": "https://huggingface.co/Comfy-Org/HunyuanVideo_repackaged/resolve/main/split_files/clip_vision/llava_llama3_vision.safetensors",
|
||||||
|
"size": "649MB"
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
"name": "LTX-Video 2B v0.9.5 Checkpoint",
|
||||||
|
"type": "checkpoint",
|
||||||
|
"base": "LTX-Video",
|
||||||
|
"save_path": "checkpoints/LTXV",
|
||||||
|
"description": "LTX-Video is the first DiT-based video generation model capable of generating high-quality videos in real-time. It produces 24 FPS videos at a 768x512 resolution faster than they can be watched. Trained on a large-scale dataset of diverse videos, the model generates high-resolution videos with realistic and varied content.",
|
||||||
|
"reference": "https://huggingface.co/Lightricks/LTX-Video",
|
||||||
|
"filename": "ltx-video-2b-v0.9.5.safetensors",
|
||||||
|
"url": "https://huggingface.co/Lightricks/LTX-Video/resolve/main/ltx-video-2b-v0.9.5.safetensors",
|
||||||
|
"size": "6.34GB"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "kolors/vae/diffusion_pytorch_model.fp16.safetensors",
|
"name": "kolors/vae/diffusion_pytorch_model.fp16.safetensors",
|
||||||
"type": "VAE",
|
"type": "VAE",
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
import os
|
import os
|
||||||
|
import shutil
|
||||||
import subprocess
|
import subprocess
|
||||||
import sys
|
import sys
|
||||||
import atexit
|
import atexit
|
||||||
@@ -34,6 +35,8 @@ else:
|
|||||||
|
|
||||||
security_check.security_check()
|
security_check.security_check()
|
||||||
|
|
||||||
|
manager_util.add_python_path_to_env()
|
||||||
|
|
||||||
cm_global.pip_blacklist = {'torch', 'torchsde', 'torchvision'}
|
cm_global.pip_blacklist = {'torch', 'torchsde', 'torchvision'}
|
||||||
cm_global.pip_downgrade_blacklist = ['torch', 'torchsde', 'torchvision', 'transformers', 'safetensors', 'kornia']
|
cm_global.pip_downgrade_blacklist = ['torch', 'torchsde', 'torchvision', 'transformers', 'safetensors', 'kornia']
|
||||||
|
|
||||||
@@ -504,7 +507,7 @@ check_bypass_ssl()
|
|||||||
# Perform install
|
# Perform install
|
||||||
processed_install = set()
|
processed_install = set()
|
||||||
script_list_path = os.path.join(folder_paths.user_directory, "default", "ComfyUI-Manager", "startup-scripts", "install-scripts.txt")
|
script_list_path = os.path.join(folder_paths.user_directory, "default", "ComfyUI-Manager", "startup-scripts", "install-scripts.txt")
|
||||||
pip_fixer = manager_util.PIPFixer(manager_util.get_installed_packages())
|
pip_fixer = manager_util.PIPFixer(manager_util.get_installed_packages(), comfy_path, manager_files_path)
|
||||||
|
|
||||||
|
|
||||||
def is_installed(name):
|
def is_installed(name):
|
||||||
@@ -693,13 +696,44 @@ def execute_migration(moves):
|
|||||||
shutil.move(x[0], x[1])
|
shutil.move(x[0], x[1])
|
||||||
print(f"[ComfyUI-Manager] MIGRATION: '{x[0]}' -> '{x[1]}'")
|
print(f"[ComfyUI-Manager] MIGRATION: '{x[0]}' -> '{x[1]}'")
|
||||||
|
|
||||||
|
|
||||||
script_executed = False
|
script_executed = False
|
||||||
|
|
||||||
# Check if script_list_path exists
|
def execute_startup_script():
|
||||||
if os.path.exists(script_list_path):
|
global script_executed
|
||||||
print("\n#######################################################################")
|
print("\n#######################################################################")
|
||||||
print("[ComfyUI-Manager] Starting dependency installation/(de)activation for the extension\n")
|
print("[ComfyUI-Manager] Starting dependency installation/(de)activation for the extension\n")
|
||||||
|
|
||||||
|
custom_nodelist_cache = None
|
||||||
|
|
||||||
|
def get_custom_node_paths():
|
||||||
|
nonlocal custom_nodelist_cache
|
||||||
|
if custom_nodelist_cache is None:
|
||||||
|
custom_nodelist_cache = set()
|
||||||
|
for base in folder_paths.get_folder_paths('custom_nodes'):
|
||||||
|
for x in os.listdir(base):
|
||||||
|
fullpath = os.path.join(base, x)
|
||||||
|
if os.path.isdir(fullpath):
|
||||||
|
custom_nodelist_cache.add(fullpath)
|
||||||
|
|
||||||
|
return custom_nodelist_cache
|
||||||
|
|
||||||
|
def execute_lazy_delete(path):
|
||||||
|
# Validate to prevent arbitrary paths from being deleted
|
||||||
|
if path not in get_custom_node_paths():
|
||||||
|
logging.error(f"## ComfyUI-Manager: The scheduled '{path}' is not a custom node path, so the deletion has been canceled.")
|
||||||
|
return
|
||||||
|
|
||||||
|
if not os.path.exists(path):
|
||||||
|
logging.info(f"## ComfyUI-Manager: SKIP-DELETE => '{path}' (already deleted)")
|
||||||
|
return
|
||||||
|
|
||||||
|
try:
|
||||||
|
shutil.rmtree(path)
|
||||||
|
logging.info(f"## ComfyUI-Manager: DELETE => '{path}'")
|
||||||
|
except Exception as e:
|
||||||
|
logging.error(f"## ComfyUI-Manager: Failed to delete '{path}' ({e})")
|
||||||
|
|
||||||
executed = set()
|
executed = set()
|
||||||
# Read each line from the file and convert it to a list using eval
|
# Read each line from the file and convert it to a list using eval
|
||||||
with open(script_list_path, 'r', encoding="UTF-8", errors="ignore") as file:
|
with open(script_list_path, 'r', encoding="UTF-8", errors="ignore") as file:
|
||||||
@@ -723,6 +757,9 @@ if os.path.exists(script_list_path):
|
|||||||
elif script[1] == "#LAZY-MIGRATION":
|
elif script[1] == "#LAZY-MIGRATION":
|
||||||
execute_migration(script[2])
|
execute_migration(script[2])
|
||||||
|
|
||||||
|
elif script[1] == "#LAZY-DELETE-NODEPACK":
|
||||||
|
execute_lazy_delete(script[2])
|
||||||
|
|
||||||
elif os.path.exists(script[0]):
|
elif os.path.exists(script[0]):
|
||||||
if script[1] == "#FORCE":
|
if script[1] == "#FORCE":
|
||||||
del script[1]
|
del script[1]
|
||||||
@@ -731,7 +768,7 @@ if os.path.exists(script_list_path):
|
|||||||
continue
|
continue
|
||||||
|
|
||||||
print(f"\n## ComfyUI-Manager: EXECUTE => {script[1:]}")
|
print(f"\n## ComfyUI-Manager: EXECUTE => {script[1:]}")
|
||||||
print(f"\n## Execute install/(de)activation script for '{script[0]}'")
|
print(f"\n## Execute management script for '{script[0]}'")
|
||||||
|
|
||||||
new_env = os.environ.copy()
|
new_env = os.environ.copy()
|
||||||
if 'COMFYUI_FOLDERS_BASE_PATH' not in new_env:
|
if 'COMFYUI_FOLDERS_BASE_PATH' not in new_env:
|
||||||
@@ -739,12 +776,12 @@ if os.path.exists(script_list_path):
|
|||||||
exit_code = process_wrap(script[1:], script[0], env=new_env)
|
exit_code = process_wrap(script[1:], script[0], env=new_env)
|
||||||
|
|
||||||
if exit_code != 0:
|
if exit_code != 0:
|
||||||
print(f"install/(de)activation script failed: {script[0]}")
|
print(f"management script failed: {script[0]}")
|
||||||
else:
|
else:
|
||||||
print(f"\n## ComfyUI-Manager: CANCELED => {script[1:]}")
|
print(f"\n## ComfyUI-Manager: CANCELED => {script[1:]}")
|
||||||
|
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
print(f"[ERROR] Failed to execute install/(de)activation script: {line} / {e}")
|
print(f"[ERROR] Failed to execute management script: {line} / {e}")
|
||||||
|
|
||||||
# Remove the script_list_path file
|
# Remove the script_list_path file
|
||||||
if os.path.exists(script_list_path):
|
if os.path.exists(script_list_path):
|
||||||
@@ -754,6 +791,12 @@ if os.path.exists(script_list_path):
|
|||||||
print("\n[ComfyUI-Manager] Startup script completed.")
|
print("\n[ComfyUI-Manager] Startup script completed.")
|
||||||
print("#######################################################################\n")
|
print("#######################################################################\n")
|
||||||
|
|
||||||
|
|
||||||
|
# Check if script_list_path exists
|
||||||
|
if os.path.exists(script_list_path):
|
||||||
|
execute_startup_script()
|
||||||
|
|
||||||
|
|
||||||
pip_fixer.fix_broken()
|
pip_fixer.fix_broken()
|
||||||
|
|
||||||
del processed_install
|
del processed_install
|
||||||
@@ -773,7 +816,10 @@ if script_executed:
|
|||||||
else:
|
else:
|
||||||
sys_argv = sys.argv.copy()
|
sys_argv = sys.argv.copy()
|
||||||
|
|
||||||
if sys.platform.startswith('win32'):
|
if sys_argv[0].endswith("__main__.py"): # this is a python module
|
||||||
|
module_name = os.path.basename(os.path.dirname(sys_argv[0]))
|
||||||
|
cmds = [sys.executable, '-m', module_name] + sys_argv[1:]
|
||||||
|
elif sys.platform.startswith('win32'):
|
||||||
cmds = ['"' + sys.executable + '"', '"' + sys_argv[0] + '"'] + sys_argv[1:]
|
cmds = ['"' + sys.executable + '"', '"' + sys_argv[0] + '"'] + sys_argv[1:]
|
||||||
else:
|
else:
|
||||||
cmds = [sys.executable] + sys_argv
|
cmds = [sys.executable] + sys_argv
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
[project]
|
[project]
|
||||||
name = "comfyui-manager"
|
name = "comfyui-manager"
|
||||||
description = "ComfyUI-Manager provides features to install and manage custom nodes for ComfyUI, as well as various functionalities to assist with ComfyUI."
|
description = "ComfyUI-Manager provides features to install and manage custom nodes for ComfyUI, as well as various functionalities to assist with ComfyUI."
|
||||||
version = "3.26"
|
version = "3.30.3"
|
||||||
license = { file = "LICENSE.txt" }
|
license = { file = "LICENSE.txt" }
|
||||||
dependencies = ["GitPython", "PyGithub", "matrix-client==0.4.0", "transformers", "huggingface-hub>0.20", "typer", "rich", "typing-extensions", "toml", "uv", "chardet"]
|
dependencies = ["GitPython", "PyGithub", "matrix-client==0.4.0", "transformers", "huggingface-hub>0.20", "typer", "rich", "typing-extensions", "toml", "uv", "chardet"]
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user