Compare commits

...

3 Commits
3.23 ... 3.24

Author SHA1 Message Date
Dr.Lt.Data
ad1b4a9a86 feat: reverse proxy
https://github.com/ltdrdata/ComfyUI-Manager/pull/795/files
2025-02-18 23:41:44 +09:00
Dr.Lt.Data
e0e3ec02b3 update DB 2025-02-18 21:08:19 +09:00
Dr.Lt.Data
a6cc392473 fix typo 2025-02-17 22:34:16 +09:00
13 changed files with 2907 additions and 2686 deletions

View File

@@ -149,7 +149,7 @@ In `ComfyUI-Manager` V3.0 and later, configuration files and dynamically generat
* Basic config files: `<USER_DIRECTORY>/default/ComfyUI-Manager/config.ini` * Basic config files: `<USER_DIRECTORY>/default/ComfyUI-Manager/config.ini`
* 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_overrides.list` * Configurable pip blacklist: `<USER_DIRECTORY>/default/ComfyUI-Manager/pip_blacklist.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`
@@ -313,6 +313,29 @@ The following settings are applied based on the section marked as `is_default`.
* This option can be used if performance issues occur in a Colab+GDrive environment. * This option can be used if performance issues occur in a Colab+GDrive environment.
## Environment Variables
The following features can be configured using environment variables:
* **COMFYUI_PATH**: The installation path of ComfyUI
* **GITHUB_ENDPOINT**: Reverse proxy configuration for environments with limited access to GitHub
* **HF_ENDPOINT**: Reverse proxy configuration for environments with limited access to Hugging Face
### Example 1:
Redirecting `https://github.com/ltdrdata/ComfyUI-Impact-Pack` to `https://mirror.ghproxy.com/https://github.com/ltdrdata/ComfyUI-Impact-Pack`
```
GITHUB_ENDPOINT=https://mirror.ghproxy.com/https://github.com
```
#### Example 2:
Changing `https://huggingface.co/path/to/somewhere` to `https://some-hf-mirror.com/path/to/somewhere`
```
HF_ENDPOINT=https://some-hf-mirror.com
```
## Scanner ## Scanner
When you run the `scan.sh` script: When you run the `scan.sh` script:

View File

@@ -21014,6 +21014,26 @@
"install_type": "git-clone", "install_type": "git-clone",
"description": "This repository explains how to accelerate image generation in ComfyUI using Pruna, an inference optimization engine that makes AI models faster, smaller, cheaper, and greener. ComfyUI is a popular node-based GUI for image generation models, for which we provide a custom compilation node that accelerates Stable Diffusion (SD) and Flux inference, while preserving output quality." "description": "This repository explains how to accelerate image generation in ComfyUI using Pruna, an inference optimization engine that makes AI models faster, smaller, cheaper, and greener. ComfyUI is a popular node-based GUI for image generation models, for which we provide a custom compilation node that accelerates Stable Diffusion (SD) and Flux inference, while preserving output quality."
}, },
{
"author": "Hellfiredragon",
"title": "comfyui-image-manipulation",
"reference": "https://github.com/Hellfiredragon/comfyui-image-manipulation",
"files": [
"https://github.com/Hellfiredragon/comfyui-image-manipulation"
],
"install_type": "git-clone",
"description": "Custom nodes to manipulate images in ComfyUI"
},
{
"author": "lunarring",
"title": "bitalino_comfy",
"reference": "https://github.com/lunarring/bitalino_comfy",
"files": [
"https://github.com/lunarring/bitalino_comfy"
],
"install_type": "git-clone",
"description": "A package implementing a Bitalino device ComfyUI custom node."
},

View File

@@ -1350,7 +1350,6 @@
"BillBum_Modified_RegText_Node", "BillBum_Modified_RegText_Node",
"BillBum_Modified_SD3_API_Node", "BillBum_Modified_SD3_API_Node",
"BillBum_Modified_Structured_LLM_Node(Imperfect)", "BillBum_Modified_Structured_LLM_Node(Imperfect)",
"BillBum_Modified_Together_API_Node",
"BillBum_Modified_VisionLM_API_Node", "BillBum_Modified_VisionLM_API_Node",
"BillBum_Modified_img2b64_url_Node", "BillBum_Modified_img2b64_url_Node",
"BillBum_NonSysPrompt_VLM_API_Node", "BillBum_NonSysPrompt_VLM_API_Node",
@@ -1379,6 +1378,7 @@
"https://github.com/AkashKarnatak/ComfyUI_faishme": [ "https://github.com/AkashKarnatak/ComfyUI_faishme": [
[ [
"Faishme Debug", "Faishme Debug",
"Faishme Load Image from Glob",
"Faishme Mannequin to Model Loader", "Faishme Mannequin to Model Loader",
"Faishme Moondream", "Faishme Moondream",
"Load Fashion Model" "Load Fashion Model"
@@ -1522,6 +1522,12 @@
"TICK (JOV) \u23f1", "TICK (JOV) \u23f1",
"TRANSFORM (JOV) \ud83c\udfdd\ufe0f", "TRANSFORM (JOV) \ud83c\udfdd\ufe0f",
"VALUE (JOV) \ud83e\uddec", "VALUE (JOV) \ud83e\uddec",
"VECTOR2 (JOV)",
"VECTOR2INT (JOV)",
"VECTOR3 (JOV)",
"VECTOR3INT (JOV)",
"VECTOR4 (JOV)",
"VECTOR4INT (JOV)",
"WAVE GEN (JOV) \ud83c\udf0a" "WAVE GEN (JOV) \ud83c\udf0a"
], ],
{ {
@@ -3001,7 +3007,6 @@
], ],
"https://github.com/Dobidop/ComfyStereo": [ "https://github.com/Dobidop/ComfyStereo": [
[ [
"LazyStereo",
"StereoImageNode" "StereoImageNode"
], ],
{ {
@@ -3076,8 +3081,6 @@
"https://github.com/DraconicDragon/ComfyUI-Venice-API": [ "https://github.com/DraconicDragon/ComfyUI-Venice-API": [
[ [
"CharCountTextBox", "CharCountTextBox",
"FluxPro11_TOGETHER",
"FluxPro_TOGETHER",
"GenerateImage_VENICE", "GenerateImage_VENICE",
"GenerateText_VENICE", "GenerateText_VENICE",
"UpscaleImage_VENICE", "UpscaleImage_VENICE",
@@ -4320,6 +4323,15 @@
"title_aux": "Hunyuan Video Resolutions" "title_aux": "Hunyuan Video Resolutions"
} }
], ],
"https://github.com/Hellfiredragon/comfyui-image-manipulation": [
[
"AlphaApplyMaskToImage",
"CreateMaskFromColorsNode"
],
{
"title_aux": "comfyui-image-manipulation"
}
],
"https://github.com/HelloVision/ComfyUI_HelloMeme": [ "https://github.com/HelloVision/ComfyUI_HelloMeme": [
[ [
"CropPortrait", "CropPortrait",
@@ -5214,10 +5226,9 @@
], ],
"https://github.com/KoreTeknology/ComfyUI-Universal-Styler": [ "https://github.com/KoreTeknology/ComfyUI-Universal-Styler": [
[ [
"Load Nai Styles Complex CSV", "\ud83d\udee1\ufe0f Load Scripts from Database",
"ShowText|pysssss", "\ud83d\udee1\ufe0f Save Script to Database (In progress)",
"Universal_Styler_Node", "\ud83d\udee1\ufe0f Set Main Channel"
"concat"
], ],
{ {
"title_aux": "ComfyUI Universal Styler" "title_aux": "ComfyUI Universal Styler"
@@ -6292,6 +6303,8 @@
"iToolsLineLoader", "iToolsLineLoader",
"iToolsLoadImagePlus", "iToolsLoadImagePlus",
"iToolsLoadImages", "iToolsLoadImages",
"iToolsLoadRandomImage",
"iToolsPreviewText",
"iToolsPromptLoader", "iToolsPromptLoader",
"iToolsPromptSaver", "iToolsPromptSaver",
"iToolsPromptStyler", "iToolsPromptStyler",
@@ -6470,9 +6483,12 @@
], ],
"https://github.com/MushroomFleet/DJZ-KokoroTTS": [ "https://github.com/MushroomFleet/DJZ-KokoroTTS": [
[ [
"KokoroTTS_LoadVoice_v1",
"KokoroTTS_SaveVoice_v1",
"KokoroTTS_v1", "KokoroTTS_v1",
"KokoroTTS_v2", "KokoroTTS_v2",
"KokoroTTS_v3" "KokoroTTS_v3",
"KokoroTTS_v4"
], ],
{ {
"title_aux": "KokoroTTS Node" "title_aux": "KokoroTTS Node"
@@ -7524,6 +7540,7 @@
"MaskBatchComposite(FaceParsing)", "MaskBatchComposite(FaceParsing)",
"MaskBlackOut(FaceParsing)", "MaskBlackOut(FaceParsing)",
"MaskBorderDissolve(FaceParsing)", "MaskBorderDissolve(FaceParsing)",
"MaskBorderDissolveAdvanced(FaceParsing)",
"MaskComposite(FaceParsing)", "MaskComposite(FaceParsing)",
"MaskCropWithBBox(FaceParsing)", "MaskCropWithBBox(FaceParsing)",
"MaskInsertWithBBox(FaceParsing)", "MaskInsertWithBBox(FaceParsing)",
@@ -8607,6 +8624,7 @@
"SDVN Dic Convert", "SDVN Dic Convert",
"SDVN Easy IPAdapter weight", "SDVN Easy IPAdapter weight",
"SDVN Exif check", "SDVN Exif check",
"SDVN Fill Square",
"SDVN Filter List", "SDVN Filter List",
"SDVN Flip Image", "SDVN Flip Image",
"SDVN Google Imagen", "SDVN Google Imagen",
@@ -9781,7 +9799,9 @@
"VrchDelayOSCControlNode", "VrchDelayOSCControlNode",
"VrchFloatKeyControlNode", "VrchFloatKeyControlNode",
"VrchFloatOSCControlNode", "VrchFloatOSCControlNode",
"VrchImageChannelLoaderNode",
"VrchImageFlipBookWebViewerNode", "VrchImageFlipBookWebViewerNode",
"VrchImagePreviewBackgroundNode",
"VrchImageSaverNode", "VrchImageSaverNode",
"VrchImageSwitchOSCControlNode", "VrchImageSwitchOSCControlNode",
"VrchImageWebViewerNode", "VrchImageWebViewerNode",
@@ -28058,7 +28078,9 @@
"https://github.com/yichengup/ComfyUI-VideoBlender": [ "https://github.com/yichengup/ComfyUI-VideoBlender": [
[ [
"VideoBlendLayer", "VideoBlendLayer",
"VideoBlendStack" "VideoBlendStack",
"VideoBlendStackAdvanced",
"VideoPreprocess"
], ],
{ {
"title_aux": "ComfyUI-VideoBlender" "title_aux": "ComfyUI-VideoBlender"

View File

File diff suppressed because it is too large Load Diff

View File

@@ -2,6 +2,9 @@ import os
import configparser import configparser
GITHUB_ENDPOINT = os.getenv('GITHUB_ENDPOINT')
def is_git_repo(path: str) -> bool: def is_git_repo(path: str) -> bool:
""" Check if the path is a git repository. """ """ Check if the path is a git repository. """
# NOTE: Checking it through `git.Repo` must be avoided. # NOTE: Checking it through `git.Repo` must be avoided.
@@ -46,16 +49,21 @@ def git_url(fullpath):
return None return None
def normalize_url(url) -> str: def normalize_url(url) -> str:
url = url.replace("git@github.com:", "https://github.com/") if 'github' in url or (GITHUB_ENDPOINT is not None and GITHUB_ENDPOINT in url):
if url.endswith('.git'): author = os.path.basename(os.path.dirname(url))
url = url[:-4] repo_name = os.path.basename(url)
url = f"https://github.com/{author}/{repo_name}"
return url return url
def normalize_url_http(url) -> str:
url = url.replace("https://github.com/", "git@github.com:")
if url.endswith('.git'):
url = url[:-4]
return url def get_url_for_clone(url):
url = normalize_url(url)
if GITHUB_ENDPOINT is not None and url.startswith('https://github.com/'):
url = GITHUB_ENDPOINT + url[18:] # url[18:] -> remove `https://github.com`
return url

View File

@@ -42,7 +42,7 @@ import manager_downloader
from node_package import InstalledNodePackage from node_package import InstalledNodePackage
version_code = [3, 23] version_code = [3, 24]
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 '')
@@ -505,6 +505,8 @@ class UnifiedManager:
def resolve_from_path(self, fullpath): def resolve_from_path(self, fullpath):
url = git_utils.git_url(fullpath) url = git_utils.git_url(fullpath)
if url: if url:
url = git_utils.normalize_url(url)
cnr = self.get_cnr_by_repo(url) cnr = self.get_cnr_by_repo(url)
commit_hash = git_utils.get_commit_hash(fullpath) commit_hash = git_utils.get_commit_hash(fullpath)
if cnr: if cnr:
@@ -1239,15 +1241,16 @@ class UnifiedManager:
if url.endswith("/"): if url.endswith("/"):
url = url[:-1] url = url[:-1]
try: try:
print(f"Download: git clone '{url}'")
# Clone the repository from the remote URL # Clone the repository from the remote URL
clone_url = git_utils.get_url_for_clone(url)
print(f"Download: git clone '{clone_url}'")
if not instant_execution and platform.system() == 'Windows': if not instant_execution and platform.system() == 'Windows':
res = manager_funcs.run_script([sys.executable, git_script_path, "--clone", get_default_custom_nodes_path(), url, repo_path], cwd=get_default_custom_nodes_path()) res = manager_funcs.run_script([sys.executable, git_script_path, "--clone", get_default_custom_nodes_path(), clone_url, repo_path], cwd=get_default_custom_nodes_path())
if res != 0: if res != 0:
return result.fail(f"Failed to clone repo: {url}") return result.fail(f"Failed to clone repo: {clone_url}")
else: else:
repo = git.Repo.clone_from(url, repo_path, recursive=True, progress=GitProgress()) repo = git.Repo.clone_from(clone_url, repo_path, recursive=True, progress=GitProgress())
repo.git.clear_cache() repo.git.clear_cache()
repo.close() repo.close()
@@ -2043,12 +2046,14 @@ async def gitclone_install(url, instant_execution=False, msg_prefix='', no_deps=
print(f"CLONE into '{repo_path}'") print(f"CLONE into '{repo_path}'")
# Clone the repository from the remote URL # Clone the repository from the remote URL
clone_url = git_utils.get_url_for_clone(url)
if not instant_execution and platform.system() == 'Windows': if not instant_execution and platform.system() == 'Windows':
res = manager_funcs.run_script([sys.executable, git_script_path, "--clone", get_default_custom_nodes_path(), url, repo_path], cwd=get_default_custom_nodes_path()) res = manager_funcs.run_script([sys.executable, git_script_path, "--clone", get_default_custom_nodes_path(), clone_url, repo_path], cwd=get_default_custom_nodes_path())
if res != 0: if res != 0:
return result.fail(f"Failed to clone '{url}' into '{repo_path}'") return result.fail(f"Failed to clone '{clone_url}' into '{repo_path}'")
else: else:
repo = git.Repo.clone_from(url, repo_path, recursive=True, progress=GitProgress()) repo = git.Repo.clone_from(clone_url, repo_path, recursive=True, progress=GitProgress())
repo.git.clear_cache() repo.git.clear_cache()
repo.close() repo.close()
@@ -2973,7 +2978,14 @@ async def restore_snapshot(snapshot_path, git_helper_extras=None):
print("cm-cli: unexpected [0001]") print("cm-cli: unexpected [0001]")
# for nightly restore # for nightly restore
git_info = info.get('git_custom_nodes') _git_info = info.get('git_custom_nodes')
git_info = {}
# normalize github repo
for k, v in _git_info.items():
norm_k = git_utils.normalize_url(k)
git_info[norm_k] = v
if git_info is not None: if git_info is not None:
todo_disable = [] todo_disable = []
todo_enable = [] todo_enable = []
@@ -2986,20 +2998,13 @@ async def restore_snapshot(snapshot_path, git_helper_extras=None):
if v[0] == 'nightly' and cnr_repo_map.get(k): if v[0] == 'nightly' and cnr_repo_map.get(k):
repo_url = cnr_repo_map.get(k) repo_url = cnr_repo_map.get(k)
normalized_url = git_utils.normalize_url(repo_url)
normalized_url1 = git_utils.normalize_url(repo_url) if normalized_url not in git_info:
normalized_url2 = git_utils.normalize_url_http(repo_url)
if normalized_url1 not in git_info and normalized_url2 not in git_info:
todo_disable.append(k) todo_disable.append(k)
else: else:
if normalized_url1 in git_info: commit_hash = git_info[normalized_url]['hash']
commit_hash = git_info[normalized_url1]['hash'] todo_checkout.append((v[1], commit_hash))
todo_checkout.append((v[1], commit_hash))
if normalized_url2 in git_info:
commit_hash = git_info[normalized_url2]['hash']
todo_checkout.append((v[1], commit_hash))
for k, v in unified_manager.nightly_inactive_nodes.items(): for k, v in unified_manager.nightly_inactive_nodes.items():
if 'comfyui-manager' in k: if 'comfyui-manager' in k:
@@ -3007,18 +3012,12 @@ async def restore_snapshot(snapshot_path, git_helper_extras=None):
if cnr_repo_map.get(k): if cnr_repo_map.get(k):
repo_url = cnr_repo_map.get(k) repo_url = cnr_repo_map.get(k)
normalized_url1 = git_utils.normalize_url(repo_url) normalized_url = git_utils.normalize_url(repo_url)
normalized_url2 = git_utils.normalize_url_http(repo_url)
if normalized_url1 in git_info: if normalized_url in git_info:
commit_hash = git_info[normalized_url1]['hash'] commit_hash = git_info[normalized_url]['hash']
todo_enable.append((k, commit_hash)) todo_enable.append((k, commit_hash))
processed_urls.append(normalized_url1) processed_urls.append(normalized_url)
if normalized_url2 in git_info:
commit_hash = git_info[normalized_url2]['hash']
todo_enable.append((k, commit_hash))
processed_urls.append(normalized_url2)
for x in todo_disable: for x in todo_disable:
unified_manager.unified_disable(x, False) unified_manager.unified_disable(x, False)
@@ -3071,21 +3070,14 @@ async def restore_snapshot(snapshot_path, git_helper_extras=None):
if repo_url is None: if repo_url is None:
continue continue
normalized_url1 = git_utils.normalize_url(repo_url) normalized_url = git_utils.normalize_url(repo_url)
normalized_url2 = git_utils.normalize_url_http(repo_url)
if normalized_url1 not in git_info and normalized_url2 not in git_info: if normalized_url not in git_info:
todo_disable.append(k2) todo_disable.append(k2)
else: else:
if normalized_url1 in git_info: commit_hash = git_info[normalized_url]['hash']
commit_hash = git_info[normalized_url1]['hash'] todo_checkout.append((k2, commit_hash))
todo_checkout.append((k2, commit_hash)) processed_urls.append(normalized_url)
processed_urls.append(normalized_url1)
if normalized_url2 in git_info:
commit_hash = git_info[normalized_url2]['hash']
todo_checkout.append((k2, commit_hash))
processed_urls.append(normalized_url2)
for k2, v2 in unified_manager.unknown_inactive_nodes.items(): for k2, v2 in unified_manager.unknown_inactive_nodes.items():
repo_url = resolve_giturl_from_path(v2[1]) repo_url = resolve_giturl_from_path(v2[1])
@@ -3093,18 +3085,12 @@ async def restore_snapshot(snapshot_path, git_helper_extras=None):
if repo_url is None: if repo_url is None:
continue continue
normalized_url1 = git_utils.normalize_url(repo_url) normalized_url = git_utils.normalize_url(repo_url)
normalized_url2 = git_utils.normalize_url_http(repo_url)
if normalized_url1 in git_info: if normalized_url in git_info:
commit_hash = git_info[normalized_url1]['hash'] commit_hash = git_info[normalized_url]['hash']
todo_enable.append((k2, commit_hash)) todo_enable.append((k2, commit_hash))
processed_urls.append(normalized_url1) processed_urls.append(normalized_url)
if normalized_url2 in git_info:
commit_hash = git_info[normalized_url2]['hash']
todo_enable.append((k2, commit_hash))
processed_urls.append(normalized_url2)
for x in todo_disable: for x in todo_disable:
unified_manager.unified_disable(x, True) unified_manager.unified_disable(x, True)

View File

@@ -11,6 +11,7 @@ from tqdm.auto import tqdm
aria2 = os.getenv('COMFYUI_MANAGER_ARIA2_SERVER') aria2 = os.getenv('COMFYUI_MANAGER_ARIA2_SERVER')
HF_ENDPOINT = os.getenv('HF_ENDPOINT') HF_ENDPOINT = os.getenv('HF_ENDPOINT')
if aria2 is not None: if aria2 is not None:
secret = os.getenv('COMFYUI_MANAGER_ARIA2_SECRET') secret = os.getenv('COMFYUI_MANAGER_ARIA2_SECRET')
url = urlparse(aria2) url = urlparse(aria2)

View File

@@ -13,6 +13,67 @@
{
"author": "if-ai",
"title": "ComfyUI-IF_Zonos [WIP]",
"reference": "https://github.com/if-ai/ComfyUI-IF_Zonos",
"files": [
"https://github.com/if-ai/ComfyUI-IF_Zonos"
],
"install_type": "git-clone",
"description": "Zonos for ComfyUI"
},
{
"author": "grinlau18",
"title": "Xiser_Nodes [WIP]",
"reference": "https://github.com/grinlau18/ComfyUI_XISER_Nodes",
"files": [
"https://github.com/grinlau18/ComfyUI_XISER_Nodes"
],
"install_type": "git-clone",
"description": "A collection of custom nodes for ComfyUI\nNOTE: The files in the repo are not organized."
},
{
"author": "LAOGOU-666",
"title": "Comfyui_StartPatch [UNSAFE]",
"reference": "https://github.com/LAOGOU-666/Comfyui_StartPatch",
"files": [
"https://github.com/LAOGOU-666/Comfyui_StartPatch"
],
"install_type": "git-clone",
"description": "This patch plugin optimizes the node information processing mechanism of the ComfyUI server, significantly improving server performance and response speed. It greatly reduces the browser page initialization waiting time. [w/Since this patch modifies key functions of ComfyUI, it is highly likely to cause compatibility issues.]"
},
{
"author": "badmike",
"title": "Prompt Factory [CONFLICT]",
"reference": "https://github.com/badmike/comfyui-prompt-factory",
"files": [
"https://github.com/badmike/comfyui-prompt-factory"
],
"install_type": "git-clone",
"description": "A modular system that adds randomness to prompt generation [w/This node pack is causing a name conflict with https://github.com/satche/comfyui-prompt-factory]"
},
{
"author": "owengillett",
"title": "ComfyUI-tilefusion",
"reference": "https://github.com/owengillett/ComfyUI-tilefusion",
"files": [
"https://github.com/owengillett/ComfyUI-tilefusion"
],
"install_type": "git-clone",
"description": "Helper nodes for generating seamless tiles."
},
{
"author": "Scaryplasmon",
"title": "ComfTrellis [WIP]",
"reference": "https://github.com/Scaryplasmon/ComfTrellis",
"files": [
"https://github.com/Scaryplasmon/ComfTrellis"
],
"install_type": "git-clone",
"description": "1 click install to run Trellis in ComfyUI\nNOTE: The files in the repo are not organized."
},
{ {
"author": "fangziheng2321", "author": "fangziheng2321",
"title": "comfyuinode_chopmask [WIP]", "title": "comfyuinode_chopmask [WIP]",

View File

@@ -741,7 +741,6 @@
"https://github.com/DraconicDragon/ComfyUI_e621_booru_toolkit": [ "https://github.com/DraconicDragon/ComfyUI_e621_booru_toolkit": [
[ [
"GetBooruPost", "GetBooruPost",
"TagEncode",
"TagWikiFetch" "TagWikiFetch"
], ],
{ {
@@ -1496,6 +1495,18 @@
"title_aux": "ComfyUI_Save2Discord" "title_aux": "ComfyUI_Save2Discord"
} }
], ],
"https://github.com/Scaryplasmon/ComfTrellis": [
[
"LoadTrellisModel",
"RembgSquare",
"SaveGLBFile",
"TrellisGrid",
"TrellisInference"
],
{
"title_aux": "ComfTrellis [WIP]"
}
],
"https://github.com/SeedV/ComfyUI-SeedV-Nodes": [ "https://github.com/SeedV/ComfyUI-SeedV-Nodes": [
[ [
"ALL_Model_UnLoader(SEEDV)", "ALL_Model_UnLoader(SEEDV)",
@@ -3055,6 +3066,16 @@
"title_aux": "ComfyUI_Grim" "title_aux": "ComfyUI_Grim"
} }
], ],
"https://github.com/grinlau18/ComfyUI_XISER_Nodes": [
[
"XIS_Float_Slider",
"XIS_INT_Slider",
"XIS_PromptsWithSwitches"
],
{
"title_aux": "Xiser_Nodes [WIP]"
}
],
"https://github.com/haodman/ComfyUI_Rain": [ "https://github.com/haodman/ComfyUI_Rain": [
[ [
"Rain_ImageSize", "Rain_ImageSize",
@@ -3285,6 +3306,14 @@
"title_aux": "comfyui-hydit" "title_aux": "comfyui-hydit"
} }
], ],
"https://github.com/if-ai/ComfyUI-IF_Zonos": [
[
"IF_ZonosTTS"
],
{
"title_aux": "ComfyUI-IF_Zonos [WIP]"
}
],
"https://github.com/ilovejohnwhite/Tracer": [ "https://github.com/ilovejohnwhite/Tracer": [
[ [
"BillyGoatNode", "BillyGoatNode",
@@ -3536,6 +3565,8 @@
], ],
"https://github.com/kandy/ComfyUI-KAndy": [ "https://github.com/kandy/ComfyUI-KAndy": [
[ [
"KAndyBatch2Index",
"KAndyBatchIndex",
"KAndyCivitImagesAPI", "KAndyCivitImagesAPI",
"KAndyCivitPromptAPI", "KAndyCivitPromptAPI",
"KAndyImageSave", "KAndyImageSave",
@@ -4502,6 +4533,15 @@
"title_aux": "comfyui-keshigom_custom" "title_aux": "comfyui-keshigom_custom"
} }
], ],
"https://github.com/owengillett/ComfyUI-tilefusion": [
[
"RepeatVideo",
"VideoGridCombine"
],
{
"title_aux": "ComfyUI-tilefusion"
}
],
"https://github.com/oyvindg/ComfyUI-TrollSuite": [ "https://github.com/oyvindg/ComfyUI-TrollSuite": [
[ [
"BinaryImageMask", "BinaryImageMask",

View File

File diff suppressed because it is too large Load Diff

View File

@@ -11,7 +11,26 @@
{
"author": "lunarring",
"title": "bitalino_comfy",
"reference": "https://github.com/lunarring/bitalino_comfy",
"files": [
"https://github.com/lunarring/bitalino_comfy"
],
"install_type": "git-clone",
"description": "A package implementing a Bitalino device ComfyUI custom node."
},
{
"author": "Hellfiredragon",
"title": "comfyui-image-manipulation",
"reference": "https://github.com/Hellfiredragon/comfyui-image-manipulation",
"files": [
"https://github.com/Hellfiredragon/comfyui-image-manipulation"
],
"install_type": "git-clone",
"description": "Custom nodes to manipulate images in ComfyUI"
},
{ {
"author": "Mohammadreza Mohseni", "author": "Mohammadreza Mohseni",
"title": "ComfyUI Mohseni Kit", "title": "ComfyUI Mohseni Kit",
@@ -673,27 +692,6 @@
], ],
"install_type": "git-clone", "install_type": "git-clone",
"description": "A custom ComfyUI node for interactive 360° panorama image previews. Panoramic 360 images are also sometimes known as VR photography (virtual reality), HDRI environments (ex: skyboxes), image spheres, spherical images, 360 pano, and 360 degree photos." "description": "A custom ComfyUI node for interactive 360° panorama image previews. Panoramic 360 images are also sometimes known as VR photography (virtual reality), HDRI environments (ex: skyboxes), image spheres, spherical images, 360 pano, and 360 degree photos."
},
{
"author": "amorano",
"title": "Jovi_MIDI",
"id": "jovi_midi",
"reference": "https://github.com/Amorano/Jovi_MIDI",
"files": [
"https://github.com/Amorano/Jovi_MIDI"
],
"install_type": "git-clone",
"description": "Read and Process data from MIDI devices inside of ComfyUI."
},
{
"author": "nkchocoai",
"title": "ComfyUI-DanbooruPromptQuiz",
"reference": "https://github.com/nkchocoai/ComfyUI-DanbooruPromptQuiz",
"files": [
"https://github.com/nkchocoai/ComfyUI-DanbooruPromptQuiz"
],
"install_type": "git-clone",
"description": "This node is for playing the game of guessing prompts by looking at images generated from prompts output by TIPO, Tagger, etc.."
} }
] ]
} }

View File

@@ -1350,7 +1350,6 @@
"BillBum_Modified_RegText_Node", "BillBum_Modified_RegText_Node",
"BillBum_Modified_SD3_API_Node", "BillBum_Modified_SD3_API_Node",
"BillBum_Modified_Structured_LLM_Node(Imperfect)", "BillBum_Modified_Structured_LLM_Node(Imperfect)",
"BillBum_Modified_Together_API_Node",
"BillBum_Modified_VisionLM_API_Node", "BillBum_Modified_VisionLM_API_Node",
"BillBum_Modified_img2b64_url_Node", "BillBum_Modified_img2b64_url_Node",
"BillBum_NonSysPrompt_VLM_API_Node", "BillBum_NonSysPrompt_VLM_API_Node",
@@ -1379,6 +1378,7 @@
"https://github.com/AkashKarnatak/ComfyUI_faishme": [ "https://github.com/AkashKarnatak/ComfyUI_faishme": [
[ [
"Faishme Debug", "Faishme Debug",
"Faishme Load Image from Glob",
"Faishme Mannequin to Model Loader", "Faishme Mannequin to Model Loader",
"Faishme Moondream", "Faishme Moondream",
"Load Fashion Model" "Load Fashion Model"
@@ -1522,6 +1522,12 @@
"TICK (JOV) \u23f1", "TICK (JOV) \u23f1",
"TRANSFORM (JOV) \ud83c\udfdd\ufe0f", "TRANSFORM (JOV) \ud83c\udfdd\ufe0f",
"VALUE (JOV) \ud83e\uddec", "VALUE (JOV) \ud83e\uddec",
"VECTOR2 (JOV)",
"VECTOR2INT (JOV)",
"VECTOR3 (JOV)",
"VECTOR3INT (JOV)",
"VECTOR4 (JOV)",
"VECTOR4INT (JOV)",
"WAVE GEN (JOV) \ud83c\udf0a" "WAVE GEN (JOV) \ud83c\udf0a"
], ],
{ {
@@ -3001,7 +3007,6 @@
], ],
"https://github.com/Dobidop/ComfyStereo": [ "https://github.com/Dobidop/ComfyStereo": [
[ [
"LazyStereo",
"StereoImageNode" "StereoImageNode"
], ],
{ {
@@ -3076,8 +3081,6 @@
"https://github.com/DraconicDragon/ComfyUI-Venice-API": [ "https://github.com/DraconicDragon/ComfyUI-Venice-API": [
[ [
"CharCountTextBox", "CharCountTextBox",
"FluxPro11_TOGETHER",
"FluxPro_TOGETHER",
"GenerateImage_VENICE", "GenerateImage_VENICE",
"GenerateText_VENICE", "GenerateText_VENICE",
"UpscaleImage_VENICE", "UpscaleImage_VENICE",
@@ -4320,6 +4323,15 @@
"title_aux": "Hunyuan Video Resolutions" "title_aux": "Hunyuan Video Resolutions"
} }
], ],
"https://github.com/Hellfiredragon/comfyui-image-manipulation": [
[
"AlphaApplyMaskToImage",
"CreateMaskFromColorsNode"
],
{
"title_aux": "comfyui-image-manipulation"
}
],
"https://github.com/HelloVision/ComfyUI_HelloMeme": [ "https://github.com/HelloVision/ComfyUI_HelloMeme": [
[ [
"CropPortrait", "CropPortrait",
@@ -5214,10 +5226,9 @@
], ],
"https://github.com/KoreTeknology/ComfyUI-Universal-Styler": [ "https://github.com/KoreTeknology/ComfyUI-Universal-Styler": [
[ [
"Load Nai Styles Complex CSV", "\ud83d\udee1\ufe0f Load Scripts from Database",
"ShowText|pysssss", "\ud83d\udee1\ufe0f Save Script to Database (In progress)",
"Universal_Styler_Node", "\ud83d\udee1\ufe0f Set Main Channel"
"concat"
], ],
{ {
"title_aux": "ComfyUI Universal Styler" "title_aux": "ComfyUI Universal Styler"
@@ -6292,6 +6303,8 @@
"iToolsLineLoader", "iToolsLineLoader",
"iToolsLoadImagePlus", "iToolsLoadImagePlus",
"iToolsLoadImages", "iToolsLoadImages",
"iToolsLoadRandomImage",
"iToolsPreviewText",
"iToolsPromptLoader", "iToolsPromptLoader",
"iToolsPromptSaver", "iToolsPromptSaver",
"iToolsPromptStyler", "iToolsPromptStyler",
@@ -6470,9 +6483,12 @@
], ],
"https://github.com/MushroomFleet/DJZ-KokoroTTS": [ "https://github.com/MushroomFleet/DJZ-KokoroTTS": [
[ [
"KokoroTTS_LoadVoice_v1",
"KokoroTTS_SaveVoice_v1",
"KokoroTTS_v1", "KokoroTTS_v1",
"KokoroTTS_v2", "KokoroTTS_v2",
"KokoroTTS_v3" "KokoroTTS_v3",
"KokoroTTS_v4"
], ],
{ {
"title_aux": "KokoroTTS Node" "title_aux": "KokoroTTS Node"
@@ -7524,6 +7540,7 @@
"MaskBatchComposite(FaceParsing)", "MaskBatchComposite(FaceParsing)",
"MaskBlackOut(FaceParsing)", "MaskBlackOut(FaceParsing)",
"MaskBorderDissolve(FaceParsing)", "MaskBorderDissolve(FaceParsing)",
"MaskBorderDissolveAdvanced(FaceParsing)",
"MaskComposite(FaceParsing)", "MaskComposite(FaceParsing)",
"MaskCropWithBBox(FaceParsing)", "MaskCropWithBBox(FaceParsing)",
"MaskInsertWithBBox(FaceParsing)", "MaskInsertWithBBox(FaceParsing)",
@@ -8607,6 +8624,7 @@
"SDVN Dic Convert", "SDVN Dic Convert",
"SDVN Easy IPAdapter weight", "SDVN Easy IPAdapter weight",
"SDVN Exif check", "SDVN Exif check",
"SDVN Fill Square",
"SDVN Filter List", "SDVN Filter List",
"SDVN Flip Image", "SDVN Flip Image",
"SDVN Google Imagen", "SDVN Google Imagen",
@@ -9781,7 +9799,9 @@
"VrchDelayOSCControlNode", "VrchDelayOSCControlNode",
"VrchFloatKeyControlNode", "VrchFloatKeyControlNode",
"VrchFloatOSCControlNode", "VrchFloatOSCControlNode",
"VrchImageChannelLoaderNode",
"VrchImageFlipBookWebViewerNode", "VrchImageFlipBookWebViewerNode",
"VrchImagePreviewBackgroundNode",
"VrchImageSaverNode", "VrchImageSaverNode",
"VrchImageSwitchOSCControlNode", "VrchImageSwitchOSCControlNode",
"VrchImageWebViewerNode", "VrchImageWebViewerNode",
@@ -28058,7 +28078,9 @@
"https://github.com/yichengup/ComfyUI-VideoBlender": [ "https://github.com/yichengup/ComfyUI-VideoBlender": [
[ [
"VideoBlendLayer", "VideoBlendLayer",
"VideoBlendStack" "VideoBlendStack",
"VideoBlendStackAdvanced",
"VideoPreprocess"
], ],
{ {
"title_aux": "ComfyUI-VideoBlender" "title_aux": "ComfyUI-VideoBlender"

View File

@@ -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.23" version = "3.24"
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"] dependencies = ["GitPython", "PyGithub", "matrix-client==0.4.0", "transformers", "huggingface-hub>0.20", "typer", "rich", "typing-extensions"]