Compare commits
3 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
ad1b4a9a86 | ||
|
|
e0e3ec02b3 | ||
|
|
a6cc392473 |
25
README.md
25
README.md
@@ -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`
|
||||
* Configurable channel lists: `<USER_DIRECTORY>/default/ComfyUI-Manager/channels.ini`
|
||||
* 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`
|
||||
* Startup script files: `<USER_DIRECTORY>/default/ComfyUI-Manager/startup-scripts`
|
||||
* 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.
|
||||
|
||||
|
||||
## 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
|
||||
When you run the `scan.sh` script:
|
||||
|
||||
|
||||
@@ -21014,6 +21014,26 @@
|
||||
"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."
|
||||
},
|
||||
{
|
||||
"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."
|
||||
},
|
||||
|
||||
|
||||
|
||||
|
||||
@@ -1350,7 +1350,6 @@
|
||||
"BillBum_Modified_RegText_Node",
|
||||
"BillBum_Modified_SD3_API_Node",
|
||||
"BillBum_Modified_Structured_LLM_Node(Imperfect)",
|
||||
"BillBum_Modified_Together_API_Node",
|
||||
"BillBum_Modified_VisionLM_API_Node",
|
||||
"BillBum_Modified_img2b64_url_Node",
|
||||
"BillBum_NonSysPrompt_VLM_API_Node",
|
||||
@@ -1379,6 +1378,7 @@
|
||||
"https://github.com/AkashKarnatak/ComfyUI_faishme": [
|
||||
[
|
||||
"Faishme Debug",
|
||||
"Faishme Load Image from Glob",
|
||||
"Faishme Mannequin to Model Loader",
|
||||
"Faishme Moondream",
|
||||
"Load Fashion Model"
|
||||
@@ -1522,6 +1522,12 @@
|
||||
"TICK (JOV) \u23f1",
|
||||
"TRANSFORM (JOV) \ud83c\udfdd\ufe0f",
|
||||
"VALUE (JOV) \ud83e\uddec",
|
||||
"VECTOR2 (JOV)",
|
||||
"VECTOR2INT (JOV)",
|
||||
"VECTOR3 (JOV)",
|
||||
"VECTOR3INT (JOV)",
|
||||
"VECTOR4 (JOV)",
|
||||
"VECTOR4INT (JOV)",
|
||||
"WAVE GEN (JOV) \ud83c\udf0a"
|
||||
],
|
||||
{
|
||||
@@ -3001,7 +3007,6 @@
|
||||
],
|
||||
"https://github.com/Dobidop/ComfyStereo": [
|
||||
[
|
||||
"LazyStereo",
|
||||
"StereoImageNode"
|
||||
],
|
||||
{
|
||||
@@ -3076,8 +3081,6 @@
|
||||
"https://github.com/DraconicDragon/ComfyUI-Venice-API": [
|
||||
[
|
||||
"CharCountTextBox",
|
||||
"FluxPro11_TOGETHER",
|
||||
"FluxPro_TOGETHER",
|
||||
"GenerateImage_VENICE",
|
||||
"GenerateText_VENICE",
|
||||
"UpscaleImage_VENICE",
|
||||
@@ -4320,6 +4323,15 @@
|
||||
"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": [
|
||||
[
|
||||
"CropPortrait",
|
||||
@@ -5214,10 +5226,9 @@
|
||||
],
|
||||
"https://github.com/KoreTeknology/ComfyUI-Universal-Styler": [
|
||||
[
|
||||
"Load Nai Styles Complex CSV",
|
||||
"ShowText|pysssss",
|
||||
"Universal_Styler_Node",
|
||||
"concat"
|
||||
"\ud83d\udee1\ufe0f Load Scripts from Database",
|
||||
"\ud83d\udee1\ufe0f Save Script to Database (In progress)",
|
||||
"\ud83d\udee1\ufe0f Set Main Channel"
|
||||
],
|
||||
{
|
||||
"title_aux": "ComfyUI Universal Styler"
|
||||
@@ -6292,6 +6303,8 @@
|
||||
"iToolsLineLoader",
|
||||
"iToolsLoadImagePlus",
|
||||
"iToolsLoadImages",
|
||||
"iToolsLoadRandomImage",
|
||||
"iToolsPreviewText",
|
||||
"iToolsPromptLoader",
|
||||
"iToolsPromptSaver",
|
||||
"iToolsPromptStyler",
|
||||
@@ -6470,9 +6483,12 @@
|
||||
],
|
||||
"https://github.com/MushroomFleet/DJZ-KokoroTTS": [
|
||||
[
|
||||
"KokoroTTS_LoadVoice_v1",
|
||||
"KokoroTTS_SaveVoice_v1",
|
||||
"KokoroTTS_v1",
|
||||
"KokoroTTS_v2",
|
||||
"KokoroTTS_v3"
|
||||
"KokoroTTS_v3",
|
||||
"KokoroTTS_v4"
|
||||
],
|
||||
{
|
||||
"title_aux": "KokoroTTS Node"
|
||||
@@ -7524,6 +7540,7 @@
|
||||
"MaskBatchComposite(FaceParsing)",
|
||||
"MaskBlackOut(FaceParsing)",
|
||||
"MaskBorderDissolve(FaceParsing)",
|
||||
"MaskBorderDissolveAdvanced(FaceParsing)",
|
||||
"MaskComposite(FaceParsing)",
|
||||
"MaskCropWithBBox(FaceParsing)",
|
||||
"MaskInsertWithBBox(FaceParsing)",
|
||||
@@ -8607,6 +8624,7 @@
|
||||
"SDVN Dic Convert",
|
||||
"SDVN Easy IPAdapter weight",
|
||||
"SDVN Exif check",
|
||||
"SDVN Fill Square",
|
||||
"SDVN Filter List",
|
||||
"SDVN Flip Image",
|
||||
"SDVN Google Imagen",
|
||||
@@ -9781,7 +9799,9 @@
|
||||
"VrchDelayOSCControlNode",
|
||||
"VrchFloatKeyControlNode",
|
||||
"VrchFloatOSCControlNode",
|
||||
"VrchImageChannelLoaderNode",
|
||||
"VrchImageFlipBookWebViewerNode",
|
||||
"VrchImagePreviewBackgroundNode",
|
||||
"VrchImageSaverNode",
|
||||
"VrchImageSwitchOSCControlNode",
|
||||
"VrchImageWebViewerNode",
|
||||
@@ -28058,7 +28078,9 @@
|
||||
"https://github.com/yichengup/ComfyUI-VideoBlender": [
|
||||
[
|
||||
"VideoBlendLayer",
|
||||
"VideoBlendStack"
|
||||
"VideoBlendStack",
|
||||
"VideoBlendStackAdvanced",
|
||||
"VideoPreprocess"
|
||||
],
|
||||
{
|
||||
"title_aux": "ComfyUI-VideoBlender"
|
||||
|
||||
4332
github-stats.json
4332
github-stats.json
File diff suppressed because it is too large
Load Diff
@@ -2,6 +2,9 @@ import os
|
||||
import configparser
|
||||
|
||||
|
||||
GITHUB_ENDPOINT = os.getenv('GITHUB_ENDPOINT')
|
||||
|
||||
|
||||
def is_git_repo(path: str) -> bool:
|
||||
""" Check if the path is a git repository. """
|
||||
# NOTE: Checking it through `git.Repo` must be avoided.
|
||||
@@ -46,16 +49,21 @@ def git_url(fullpath):
|
||||
|
||||
return None
|
||||
|
||||
|
||||
def normalize_url(url) -> str:
|
||||
url = url.replace("git@github.com:", "https://github.com/")
|
||||
if url.endswith('.git'):
|
||||
url = url[:-4]
|
||||
if 'github' in url or (GITHUB_ENDPOINT is not None and GITHUB_ENDPOINT in url):
|
||||
author = os.path.basename(os.path.dirname(url))
|
||||
repo_name = os.path.basename(url)
|
||||
url = f"https://github.com/{author}/{repo_name}"
|
||||
|
||||
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
|
||||
|
||||
@@ -42,7 +42,7 @@ import manager_downloader
|
||||
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 '')
|
||||
|
||||
|
||||
@@ -505,6 +505,8 @@ class UnifiedManager:
|
||||
def resolve_from_path(self, fullpath):
|
||||
url = git_utils.git_url(fullpath)
|
||||
if url:
|
||||
url = git_utils.normalize_url(url)
|
||||
|
||||
cnr = self.get_cnr_by_repo(url)
|
||||
commit_hash = git_utils.get_commit_hash(fullpath)
|
||||
if cnr:
|
||||
@@ -1239,15 +1241,16 @@ class UnifiedManager:
|
||||
if url.endswith("/"):
|
||||
url = url[:-1]
|
||||
try:
|
||||
print(f"Download: git clone '{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':
|
||||
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:
|
||||
return result.fail(f"Failed to clone repo: {url}")
|
||||
return result.fail(f"Failed to clone repo: {clone_url}")
|
||||
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.close()
|
||||
|
||||
@@ -2043,12 +2046,14 @@ async def gitclone_install(url, instant_execution=False, msg_prefix='', no_deps=
|
||||
print(f"CLONE into '{repo_path}'")
|
||||
|
||||
# Clone the repository from the remote URL
|
||||
clone_url = git_utils.get_url_for_clone(url)
|
||||
|
||||
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:
|
||||
return result.fail(f"Failed to clone '{url}' into '{repo_path}'")
|
||||
return result.fail(f"Failed to clone '{clone_url}' into '{repo_path}'")
|
||||
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.close()
|
||||
|
||||
@@ -2973,7 +2978,14 @@ async def restore_snapshot(snapshot_path, git_helper_extras=None):
|
||||
print("cm-cli: unexpected [0001]")
|
||||
|
||||
# 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:
|
||||
todo_disable = []
|
||||
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):
|
||||
repo_url = cnr_repo_map.get(k)
|
||||
normalized_url = git_utils.normalize_url(repo_url)
|
||||
|
||||
normalized_url1 = 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(k)
|
||||
else:
|
||||
if normalized_url1 in git_info:
|
||||
commit_hash = git_info[normalized_url1]['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))
|
||||
commit_hash = git_info[normalized_url]['hash']
|
||||
todo_checkout.append((v[1], commit_hash))
|
||||
|
||||
for k, v in unified_manager.nightly_inactive_nodes.items():
|
||||
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):
|
||||
repo_url = cnr_repo_map.get(k)
|
||||
normalized_url1 = git_utils.normalize_url(repo_url)
|
||||
normalized_url2 = git_utils.normalize_url_http(repo_url)
|
||||
normalized_url = git_utils.normalize_url(repo_url)
|
||||
|
||||
if normalized_url1 in git_info:
|
||||
commit_hash = git_info[normalized_url1]['hash']
|
||||
if normalized_url in git_info:
|
||||
commit_hash = git_info[normalized_url]['hash']
|
||||
todo_enable.append((k, commit_hash))
|
||||
processed_urls.append(normalized_url1)
|
||||
|
||||
if normalized_url2 in git_info:
|
||||
commit_hash = git_info[normalized_url2]['hash']
|
||||
todo_enable.append((k, commit_hash))
|
||||
processed_urls.append(normalized_url2)
|
||||
processed_urls.append(normalized_url)
|
||||
|
||||
for x in todo_disable:
|
||||
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:
|
||||
continue
|
||||
|
||||
normalized_url1 = git_utils.normalize_url(repo_url)
|
||||
normalized_url2 = git_utils.normalize_url_http(repo_url)
|
||||
normalized_url = git_utils.normalize_url(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)
|
||||
else:
|
||||
if normalized_url1 in git_info:
|
||||
commit_hash = git_info[normalized_url1]['hash']
|
||||
todo_checkout.append((k2, commit_hash))
|
||||
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)
|
||||
commit_hash = git_info[normalized_url]['hash']
|
||||
todo_checkout.append((k2, commit_hash))
|
||||
processed_urls.append(normalized_url)
|
||||
|
||||
for k2, v2 in unified_manager.unknown_inactive_nodes.items():
|
||||
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:
|
||||
continue
|
||||
|
||||
normalized_url1 = git_utils.normalize_url(repo_url)
|
||||
normalized_url2 = git_utils.normalize_url_http(repo_url)
|
||||
normalized_url = git_utils.normalize_url(repo_url)
|
||||
|
||||
if normalized_url1 in git_info:
|
||||
commit_hash = git_info[normalized_url1]['hash']
|
||||
if normalized_url in git_info:
|
||||
commit_hash = git_info[normalized_url]['hash']
|
||||
todo_enable.append((k2, commit_hash))
|
||||
processed_urls.append(normalized_url1)
|
||||
|
||||
if normalized_url2 in git_info:
|
||||
commit_hash = git_info[normalized_url2]['hash']
|
||||
todo_enable.append((k2, commit_hash))
|
||||
processed_urls.append(normalized_url2)
|
||||
processed_urls.append(normalized_url)
|
||||
|
||||
for x in todo_disable:
|
||||
unified_manager.unified_disable(x, True)
|
||||
|
||||
@@ -11,6 +11,7 @@ from tqdm.auto import tqdm
|
||||
aria2 = os.getenv('COMFYUI_MANAGER_ARIA2_SERVER')
|
||||
HF_ENDPOINT = os.getenv('HF_ENDPOINT')
|
||||
|
||||
|
||||
if aria2 is not None:
|
||||
secret = os.getenv('COMFYUI_MANAGER_ARIA2_SECRET')
|
||||
url = urlparse(aria2)
|
||||
|
||||
@@ -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",
|
||||
"title": "comfyuinode_chopmask [WIP]",
|
||||
|
||||
@@ -741,7 +741,6 @@
|
||||
"https://github.com/DraconicDragon/ComfyUI_e621_booru_toolkit": [
|
||||
[
|
||||
"GetBooruPost",
|
||||
"TagEncode",
|
||||
"TagWikiFetch"
|
||||
],
|
||||
{
|
||||
@@ -1496,6 +1495,18 @@
|
||||
"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": [
|
||||
[
|
||||
"ALL_Model_UnLoader(SEEDV)",
|
||||
@@ -3055,6 +3066,16 @@
|
||||
"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": [
|
||||
[
|
||||
"Rain_ImageSize",
|
||||
@@ -3285,6 +3306,14 @@
|
||||
"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": [
|
||||
[
|
||||
"BillyGoatNode",
|
||||
@@ -3536,6 +3565,8 @@
|
||||
],
|
||||
"https://github.com/kandy/ComfyUI-KAndy": [
|
||||
[
|
||||
"KAndyBatch2Index",
|
||||
"KAndyBatchIndex",
|
||||
"KAndyCivitImagesAPI",
|
||||
"KAndyCivitPromptAPI",
|
||||
"KAndyImageSave",
|
||||
@@ -4502,6 +4533,15 @@
|
||||
"title_aux": "comfyui-keshigom_custom"
|
||||
}
|
||||
],
|
||||
"https://github.com/owengillett/ComfyUI-tilefusion": [
|
||||
[
|
||||
"RepeatVideo",
|
||||
"VideoGridCombine"
|
||||
],
|
||||
{
|
||||
"title_aux": "ComfyUI-tilefusion"
|
||||
}
|
||||
],
|
||||
"https://github.com/oyvindg/ComfyUI-TrollSuite": [
|
||||
[
|
||||
"BinaryImageMask",
|
||||
|
||||
File diff suppressed because it is too large
Load Diff
@@ -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",
|
||||
"title": "ComfyUI Mohseni Kit",
|
||||
@@ -673,27 +692,6 @@
|
||||
],
|
||||
"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."
|
||||
},
|
||||
{
|
||||
"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.."
|
||||
}
|
||||
]
|
||||
}
|
||||
|
||||
@@ -1350,7 +1350,6 @@
|
||||
"BillBum_Modified_RegText_Node",
|
||||
"BillBum_Modified_SD3_API_Node",
|
||||
"BillBum_Modified_Structured_LLM_Node(Imperfect)",
|
||||
"BillBum_Modified_Together_API_Node",
|
||||
"BillBum_Modified_VisionLM_API_Node",
|
||||
"BillBum_Modified_img2b64_url_Node",
|
||||
"BillBum_NonSysPrompt_VLM_API_Node",
|
||||
@@ -1379,6 +1378,7 @@
|
||||
"https://github.com/AkashKarnatak/ComfyUI_faishme": [
|
||||
[
|
||||
"Faishme Debug",
|
||||
"Faishme Load Image from Glob",
|
||||
"Faishme Mannequin to Model Loader",
|
||||
"Faishme Moondream",
|
||||
"Load Fashion Model"
|
||||
@@ -1522,6 +1522,12 @@
|
||||
"TICK (JOV) \u23f1",
|
||||
"TRANSFORM (JOV) \ud83c\udfdd\ufe0f",
|
||||
"VALUE (JOV) \ud83e\uddec",
|
||||
"VECTOR2 (JOV)",
|
||||
"VECTOR2INT (JOV)",
|
||||
"VECTOR3 (JOV)",
|
||||
"VECTOR3INT (JOV)",
|
||||
"VECTOR4 (JOV)",
|
||||
"VECTOR4INT (JOV)",
|
||||
"WAVE GEN (JOV) \ud83c\udf0a"
|
||||
],
|
||||
{
|
||||
@@ -3001,7 +3007,6 @@
|
||||
],
|
||||
"https://github.com/Dobidop/ComfyStereo": [
|
||||
[
|
||||
"LazyStereo",
|
||||
"StereoImageNode"
|
||||
],
|
||||
{
|
||||
@@ -3076,8 +3081,6 @@
|
||||
"https://github.com/DraconicDragon/ComfyUI-Venice-API": [
|
||||
[
|
||||
"CharCountTextBox",
|
||||
"FluxPro11_TOGETHER",
|
||||
"FluxPro_TOGETHER",
|
||||
"GenerateImage_VENICE",
|
||||
"GenerateText_VENICE",
|
||||
"UpscaleImage_VENICE",
|
||||
@@ -4320,6 +4323,15 @@
|
||||
"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": [
|
||||
[
|
||||
"CropPortrait",
|
||||
@@ -5214,10 +5226,9 @@
|
||||
],
|
||||
"https://github.com/KoreTeknology/ComfyUI-Universal-Styler": [
|
||||
[
|
||||
"Load Nai Styles Complex CSV",
|
||||
"ShowText|pysssss",
|
||||
"Universal_Styler_Node",
|
||||
"concat"
|
||||
"\ud83d\udee1\ufe0f Load Scripts from Database",
|
||||
"\ud83d\udee1\ufe0f Save Script to Database (In progress)",
|
||||
"\ud83d\udee1\ufe0f Set Main Channel"
|
||||
],
|
||||
{
|
||||
"title_aux": "ComfyUI Universal Styler"
|
||||
@@ -6292,6 +6303,8 @@
|
||||
"iToolsLineLoader",
|
||||
"iToolsLoadImagePlus",
|
||||
"iToolsLoadImages",
|
||||
"iToolsLoadRandomImage",
|
||||
"iToolsPreviewText",
|
||||
"iToolsPromptLoader",
|
||||
"iToolsPromptSaver",
|
||||
"iToolsPromptStyler",
|
||||
@@ -6470,9 +6483,12 @@
|
||||
],
|
||||
"https://github.com/MushroomFleet/DJZ-KokoroTTS": [
|
||||
[
|
||||
"KokoroTTS_LoadVoice_v1",
|
||||
"KokoroTTS_SaveVoice_v1",
|
||||
"KokoroTTS_v1",
|
||||
"KokoroTTS_v2",
|
||||
"KokoroTTS_v3"
|
||||
"KokoroTTS_v3",
|
||||
"KokoroTTS_v4"
|
||||
],
|
||||
{
|
||||
"title_aux": "KokoroTTS Node"
|
||||
@@ -7524,6 +7540,7 @@
|
||||
"MaskBatchComposite(FaceParsing)",
|
||||
"MaskBlackOut(FaceParsing)",
|
||||
"MaskBorderDissolve(FaceParsing)",
|
||||
"MaskBorderDissolveAdvanced(FaceParsing)",
|
||||
"MaskComposite(FaceParsing)",
|
||||
"MaskCropWithBBox(FaceParsing)",
|
||||
"MaskInsertWithBBox(FaceParsing)",
|
||||
@@ -8607,6 +8624,7 @@
|
||||
"SDVN Dic Convert",
|
||||
"SDVN Easy IPAdapter weight",
|
||||
"SDVN Exif check",
|
||||
"SDVN Fill Square",
|
||||
"SDVN Filter List",
|
||||
"SDVN Flip Image",
|
||||
"SDVN Google Imagen",
|
||||
@@ -9781,7 +9799,9 @@
|
||||
"VrchDelayOSCControlNode",
|
||||
"VrchFloatKeyControlNode",
|
||||
"VrchFloatOSCControlNode",
|
||||
"VrchImageChannelLoaderNode",
|
||||
"VrchImageFlipBookWebViewerNode",
|
||||
"VrchImagePreviewBackgroundNode",
|
||||
"VrchImageSaverNode",
|
||||
"VrchImageSwitchOSCControlNode",
|
||||
"VrchImageWebViewerNode",
|
||||
@@ -28058,7 +28078,9 @@
|
||||
"https://github.com/yichengup/ComfyUI-VideoBlender": [
|
||||
[
|
||||
"VideoBlendLayer",
|
||||
"VideoBlendStack"
|
||||
"VideoBlendStack",
|
||||
"VideoBlendStackAdvanced",
|
||||
"VideoPreprocess"
|
||||
],
|
||||
{
|
||||
"title_aux": "ComfyUI-VideoBlender"
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
[project]
|
||||
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."
|
||||
version = "3.23"
|
||||
version = "3.24"
|
||||
license = { file = "LICENSE.txt" }
|
||||
dependencies = ["GitPython", "PyGithub", "matrix-client==0.4.0", "transformers", "huggingface-hub>0.20", "typer", "rich", "typing-extensions"]
|
||||
|
||||
|
||||
Reference in New Issue
Block a user