Compare commits

..

18 Commits

Author SHA1 Message Date
Dr.Lt.Data
68aa534e1d fixed: An issue where restore malfunctioned since channel validation patch.
https://github.com/Comfy-Org/comfy-cli/issues/253
2025-03-19 01:24:20 +09:00
Dr.Lt.Data
7fd94a401b update DB 2025-03-19 00:23:24 +09:00
kukuo6666
2b9cec50ce Update custom-node-list.json (#1674)
This ComfyUI custom node provides tools for processing equirectangular images. Currently supports converting equirectangular images to cubemap format.
2025-03-18 23:48:09 +09:00
Dr.Lt.Data
d1a80cf082 update DB 2025-03-18 02:44:18 +09:00
Dr.Lt.Data
fb445aa510 update DB 2025-03-18 00:59:25 +09:00
Juggernaut
4b904934ef AttributeError fix (#1672) 2025-03-18 00:49:37 +09:00
Jinwoo Park (Curt)
d6295a00e6 Update custom-node-list.json (#1671)
It works the same as [human-parser-comfyui-node](https://github.com/cozymantis/human-parser-comfyui-node), but I re-implemented InPlaceABNSync in pure Python so that it doesn't need a runtime build.

The pros and cons of this change:

pros
- The initial runtime is faster because it doesn't require a runtime build.
- No runtime error and complex setups for building the C++ code.

cons:
- After the initial execution, it could be slower than the original InPlaceABNSync.

related issue: https://github.com/cozymantis/human-parser-comfyui-node/issues/22
2025-03-18 00:35:14 +09:00
Laureηt
3b01673829 add comfyui-piq to custom-node-list.json (#1668)
* add comfyui-piq to custom-node-list.json

* Update custom-node-list.json

* Update custom-node-list.json

---------

Co-authored-by: Dr.Lt.Data <128333288+ltdrdata@users.noreply.github.com>
2025-03-17 00:39:37 +09:00
Dr.Lt.Data
a5e83a807f update DB 2025-03-17 00:37:22 +09:00
ImpactFrames
ddd766ce58 added nodes corrected id to match author name (#1669) 2025-03-17 00:35:39 +09:00
Dr.Lt.Data
a6d2fd36fb update DB 2025-03-16 04:26:11 +09:00
CY-CHENYUE
9156d6bdba Update custom-node-list.json (#1660)
* Update custom-node-list.json

* Update custom-node-list.json

---------

Co-authored-by: Dr.Lt.Data <128333288+ltdrdata@users.noreply.github.com>
2025-03-15 21:01:36 +09:00
Robin Huang
d18a3ffeff chore(publish): update GitHub Actions workflow for node publishing (#1661)
- Add permissions for issue writing
- Update action version to v1 for publish-node-action
- Add condition to run job only for 'ltdrdata' repository owner

Co-authored-by: snomiao <snomiao+comfy-pr@gmail.com>
2025-03-15 20:56:06 +09:00
Dr.Lt.Data
e933eaa2b0 fixed: Skip comfyui-frontend-package fixing when using an older version of ComfyUI.
https://github.com/ltdrdata/ComfyUI-Manager/issues/1662
2025-03-15 20:50:30 +09:00
Dr.Lt.Data
5393653ddc improved: restore_snapshot - better log message
fixed: restore_snapshot - failing channel validation

https://github.com/ltdrdata/ComfyUI-Manager/issues/1659

https://github.com/ltdrdata/ComfyUI-Manager/issues/1664
2025-03-15 20:36:50 +09:00
Dr.Lt.Data
1f3274d3f5 fixed: Removed -> str | None typing.
- Python versions below 3.10 do not support it.

https://github.com/ltdrdata/ComfyUI-Manager/issues/1663
2025-03-15 20:14:08 +09:00
Dr.Lt.Data
39eaa76b8a fixed: remove migration code completely
https://github.com/ltdrdata/ComfyUI-Manager/issues/1659
2025-03-14 18:24:30 +09:00
Dr.Lt.Data
e5396713ce fixed: gitclone_install - add mode 2025-03-14 12:59:06 +09:00
20 changed files with 6181 additions and 4106 deletions

View File

@@ -7,15 +7,19 @@ on:
paths:
- "pyproject.toml"
permissions:
issues: write
jobs:
publish-node:
name: Publish Custom Node to registry
runs-on: ubuntu-latest
if: ${{ github.repository_owner == 'ltdrdata' }}
steps:
- name: Check out code
uses: actions/checkout@v4
- name: Publish Custom Node
uses: Comfy-Org/publish-node-action@main
uses: Comfy-Org/publish-node-action@v1
with:
## Add your own personal access token to your Github Repository secrets and reference it here.
personal_access_token: ${{ secrets.REGISTRY_ACCESS_TOKEN }}
personal_access_token: ${{ secrets.REGISTRY_ACCESS_TOKEN }}

View File

@@ -314,9 +314,6 @@ The following settings are applied based on the section marked as `is_default`.
* Use `aria2` as downloader
* [howto](docs/en/use_aria2.md)
* If you add the item `skip_migration_check = True` to `config.ini`, it will not check whether there are nodes that can be migrated at startup.
* This option can be used if performance issues occur in a Colab+GDrive environment.
## Environment Variables

View File

@@ -1271,20 +1271,6 @@ def export_custom_node_ids(
print(f"{x['id']}@unknown", file=output_file)
@app.command(
"migrate",
help="Migrate legacy node system to new node system",
)
def migrate(
user_directory: str = typer.Option(
None,
help="user directory"
)
):
cmd_ctx.set_user_directory(user_directory)
asyncio.run(unified_manager.migrate_unmanaged_nodes())
if __name__ == '__main__':
sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0])
sys.exit(app())

View File

@@ -3693,6 +3693,18 @@
"nodename_pattern": "- Ostris$",
"description": "This is a collection of custom nodes for ComfyUI that I made for some QOL. I will be adding much more advanced ones in the future once I get more familiar with the API."
},
{
"author": "ostris",
"title": "Flex.1 tools",
"id": "ostris",
"reference": "https://github.com/ostris/ComfyUI-FlexTools",
"files": [
"https://github.com/ostris/ComfyUI-FlexTools"
],
"install_type": "git-clone",
"nodename_pattern": "- Ostris$",
"description": "Some tools to help with [a/Flex.1-alpha](https://huggingface.co/ostris/Flex.1-alpha) inference on Comfy UI."
},
{
"author": "0xbitches",
"title": "Latent Consistency Model for ComfyUI",
@@ -6999,6 +7011,16 @@
"install_type": "git-clone",
"description": "This project is an unofficial ComfyUI implementation of [a/InvSR](https://github.com/zsyOAOA/InvSR) (Arbitrary-steps Image Super-resolution via Diffusion Inversion)"
},
{
"author": "yuvraj108c",
"title": "ComfyUI Thera",
"reference": "https://github.com/yuvraj108c/ComfyUI-Thera",
"files": [
"https://github.com/yuvraj108c/ComfyUI-Thera"
],
"install_type": "git-clone",
"description": "This project is an unofficial ComfyUI implementation of [a/Thera](https://github.com/prs-eth/thera) (Aliasing-Free Arbitrary-Scale Super-Resolution with Neural Heat Fields)"
},
{
"author": "blepping",
"title": "ComfyUI-bleh",
@@ -7703,6 +7725,16 @@
"install_type": "git-clone",
"description": "An advanced custom node for ComfyUI that provides optimized access to Wan2.1, a state-of-the-art video foundation model suite. The WanVideoKsampler node features intelligent memory management to enable higher resolution outputs and longer video sequences, even on consumer-grade hardware."
},
{
"author": "ShmuelRonen",
"title": "ComfyUI-PixArt_XL",
"reference": "https://github.com/ShmuelRonen/ComfyUI-PixArt_XL",
"files": [
"https://github.com/ShmuelRonen/ComfyUI-PixArt_XL"
],
"install_type": "git-clone",
"description": "A ComfyUI extension that integrates PixArt-Alpha models directly into ComfyUI with advanced memory management."
},
{
"author": "redhottensors",
"title": "ComfyUI-Prediction",
@@ -7829,6 +7861,16 @@
"install_type": "git-clone",
"description": "ComfyUI integration for Pollinations API - Generate images and text based on user prompts"
},
{
"author": "1038lab",
"title": "Comfyui-Spark-TTS",
"reference": "https://github.com/1038lab/ComfyUI-SparkTTS",
"files": [
"https://github.com/1038lab/ComfyUI-SparkTTS"
],
"install_type": "git-clone",
"description": "ComfyUI-SparkTTS is a custom ComfyUI node implementation of SparkTTS, an advanced text-to-speech system that harnesses the power of large language models (LLMs) to generate highly accurate and natural-sounding speech."
},
{
"author": "Klinter",
"title": "Klinter_nodes",
@@ -8766,8 +8808,8 @@
},
{
"author": "impactframes",
"title": "ComfyUI-IF_AI_tools",
"id": "if-ai-tools",
"title": "IF_AI_tools",
"id": "impactframes-tools",
"reference": "https://github.com/if-ai/ComfyUI-IF_AI_tools",
"files": [
"https://github.com/if-ai/ComfyUI-IF_AI_tools"
@@ -8777,8 +8819,8 @@
},
{
"author": "impactframes",
"title": "ComfyUI-IF_AI_WishperSpeechNode",
"id": "if-ai-whisper-speech",
"title": "IF_AI_WishperSpeechNode",
"id": "impactframes-whisper-speech",
"reference": "https://github.com/if-ai/ComfyUI-IF_AI_WishperSpeechNode",
"files": [
"https://github.com/if-ai/ComfyUI-IF_AI_WishperSpeechNode"
@@ -8788,8 +8830,8 @@
},
{
"author": "impactframes",
"title": "ComfyUI-IF_AI_HFDownloaderNode",
"id": "if-ai-hfdownloader",
"title": "IF_AI_HFDownloaderNode",
"id": "impactframes-hfdownloader",
"reference": "https://github.com/if-ai/ComfyUI-IF_AI_HFDownloaderNode",
"files": [
"https://github.com/if-ai/ComfyUI-IF_AI_HFDownloaderNode"
@@ -8799,7 +8841,8 @@
},
{
"author": "impactframes",
"title": "ComfyUI-IF_MemoAvatar",
"title": "IF_MemoAvatar",
"id": "impactframes-memoavatar",
"reference": "https://github.com/if-ai/ComfyUI-IF_MemoAvatar",
"files": [
"https://github.com/if-ai/ComfyUI-IF_MemoAvatar"
@@ -8809,7 +8852,8 @@
},
{
"author": "impactframes",
"title": "ComfyUI-IF_Trellis",
"title": "IF_Trellis",
"id": "impactframes-trellis",
"reference": "https://github.com/if-ai/ComfyUI-IF_Trellis",
"files": [
"https://github.com/if-ai/ComfyUI-IF_Trellis"
@@ -8820,6 +8864,7 @@
{
"author": "impactframes",
"title": "IF_DatasetMkr",
"id": "impactframes-datasetmkr",
"reference": "https://github.com/if-ai/ComfyUI-IF_DatasetMkr",
"files": [
"https://github.com/if-ai/ComfyUI-IF_DatasetMkr"
@@ -8827,6 +8872,61 @@
"install_type": "git-clone",
"description": "Create Video datasets straight from YT or a video file path"
},
{
"author": "impactframes",
"title": "IF_ParlerTTSNode",
"id": "impactframes-parlertts",
"reference": "https://github.com/if-ai/ComfyUI-IF_AI_ParlerTTSNode",
"files": [
"https://github.com/if-ai/ComfyUI-IF_AI_ParlerTTSNode"
],
"install_type": "git-clone",
"description": "Parler TTS is a zeroshot voice synthesis with emotion and entonations, you can control the voice style via text prompt"
},
{
"author": "impactframes",
"title": "IF_Dreamtalk",
"id": "impactframes-dreamtalk",
"reference": "https://github.com/if-ai/ComfyUI-IF_AI_Dreamtalk",
"files": [
"https://github.com/if-ai/ComfyUI-IF_AI_Dreamtalk"
],
"install_type": "git-clone",
"description": "Talking avatars Heads for the IF_AI tools integrates dreamtalk in ComfyUI"
},
{
"author": "impactframes",
"title": "IF_VideoPrompts",
"id": "impactframes-videoprompts",
"reference": "https://github.com/if-ai/ComfyUI-IF_VideoPrompts",
"files": [
"https://github.com/if-ai/ComfyUI-IF_VideoPrompts"
],
"install_type": "git-clone",
"description": "ComfyUI extension for video-based prompting and processing with support for various models and video processing capabilities"
},
{
"author": "impactframes",
"title": "IF_LLM",
"id": "impactframes-llm",
"reference": "https://github.com/if-ai/ComfyUI-IF_LLM",
"files": [
"https://github.com/if-ai/ComfyUI-IF_LLM"
],
"install_type": "git-clone",
"description": "Run Local and API LLMs, Features Conditioning manipulation via Omost, supports Ollama, LlamaCPP LMstudio, Koboldcpp, TextGen, Transformers or via APIs Anthropic, Groq, OpenAI, Google Gemini, Mistral, xAI and create your own charcters assistants (SystemPrompts) with custom presets and muchmore"
},
{
"author": "impactframes",
"title": "IF_AI_LoadImages",
"id": "impactframes-loadimages",
"reference": "https://github.com/if-ai/ComfyUI_IF_AI_LoadImages",
"files": [
"https://github.com/if-ai/ComfyUI_IF_AI_LoadImages"
],
"install_type": "git-clone",
"description": "It Load Images with subfolders form arbitrary folders previous on node outputs lists- convinient selection via file browser"
},
{
"author": "dmMaze",
"title": "Sketch2Manga",
@@ -9330,7 +9430,7 @@
"https://github.com/KytraScript/ComfyUI_MatAnyone_Kytra"
],
"install_type": "git-clone",
"description": "This is a ComfyUI node for [a/MatAnyone](https://github.com/pq-yang/MatAnyone), a state-of-the-art video matting model that can remove backgrounds from videos using just a single mask for the first frame for enhanced/guided video matting."
"description": "Kytra's MatAnyone (Video Matting) implementation for ComfyUI - Based on pq-yang/MatAnyone"
},
{
"author": "1mckw",
@@ -9340,7 +9440,7 @@
"https://github.com/1mckw/Comfyui-Gelbooru"
],
"install_type": "git-clone",
"description": "Get random images from gelbooru, support multiple tag searches, exclude tags, etc. user and api key are optional."
"description": "Get random images from gelbooru or rule34."
},
{
"author": "NeuralSamurAI",
@@ -11248,6 +11348,16 @@
"install_type": "git-clone",
"description": "Run [a/Replicate models](https://replicate.com/explore) in ComfyUI."
},
{
"author": "fofr",
"title": "ComfyUI-Basic-Auth",
"reference": "https://github.com/fofr/comfyui-basic-auth",
"files": [
"https://github.com/fofr/comfyui-basic-auth"
],
"install_type": "git-clone",
"description": "A basic auth middleware for ComfyUI"
},
{
"author": "cfreilich",
"title": "Virtuoso Nodes for ComfyUI",
@@ -11709,7 +11819,7 @@
"https://github.com/gonzalu/ComfyUI_YFG_Comical"
],
"install_type": "git-clone",
"description": "Image Historgram Generator - Outputs a set of images displaying the Histogram of the input image. Nodes: img2histograms, img2histogramsSelf"
"description": "Utility custom nodes for special effects, image manipulation and quality of life tools."
},
{
"author": "ruiqutech",
@@ -11933,7 +12043,7 @@
"https://github.com/ArcherFMY/Diffusion360_ComfyUI"
],
"install_type": "git-clone",
"description": "ComfyUI plugin of [a/SD-T2I-360PanoImage](https://github.com/ArcherFMY/SD-T2I-360PanoImage).\nbase t2i-pipeline for generating 512*1024 panorama image from text input"
"description": "Generating seamless 360 degree panoramic image through text or perspective image."
},
{
"author": "Makeezi",
@@ -12043,7 +12153,7 @@
"https://github.com/fexploit/ComfyUI-AutoLabel"
],
"install_type": "git-clone",
"description": "ComfyUI-AutoLabel is a custom node for ComfyUI that uses BLIP (Bootstrapping Language-Image Pre-training) to generate detailed descriptions of the main object in an image. This node leverages the power of BLIP to provide accurate and context-aware captions for images."
"description": "ComfyUI-AutoLabel is a custom node for ComfyUI that uses BLIP (Bootstrapping Language-Image Pre-training) to generate detailed descriptions of the main object in an image. This node leverages the power of BLIP to provide accurate and context-aware captions for images. by Fexploit."
},
{
"author": "fexploit",
@@ -12315,7 +12425,7 @@
"https://github.com/AshMartian/ComfyUI-DirGir"
],
"install_type": "git-clone",
"description": "A collection of ComfyUI directory automation utility nodes. Directory Get It Right adds a GUI directory browser, and smart directory loop/iteration node that supports regex and file extension filtering."
"description": "A collection of ComfyUI directory automation utility nodes. Directory Get-It-Right adds a GUI directory browser, and a smart directory loop/iteration node that supports regex + file extension filtering + sorting methods."
},
{
"author": "SozeInc",
@@ -14160,17 +14270,6 @@
"install_type": "git-clone",
"description": "Optional wildcards in ComfyUI"
},
{
"author": "Makki_Shizu",
"title": "ComfyUI-SaveAnimatedGIF",
"id": "SaveAnimatedGIF",
"reference": "https://github.com/MakkiShizu/ComfyUI-SaveAnimatedGIF",
"files": [
"https://github.com/MakkiShizu/ComfyUI-SaveAnimatedGIF"
],
"install_type": "git-clone",
"description": "Save animated GIF format nodes in ComfyUI"
},
{
"author": "JosefKuchar",
"title": "ComfyUI-AdvancedTiling",
@@ -14689,6 +14788,46 @@
"install_type": "git-clone",
"description": "ComfyUI nodes to use [a/ChatGen](https://github.com/chengyou-jia/ChatGen)"
},
{
"author": "leeguandong",
"title": "ComfyUI_DeepSeekVL2",
"reference": "https://github.com/leeguandong/ComfyUI_DeepSeekVL2",
"files": [
"https://github.com/leeguandong/ComfyUI_DeepSeekVL2"
],
"install_type": "git-clone",
"description": "ComfyUI nodes to use [a/DeepSeek-VL2](https://github.com/deepseek-ai/DeepSeek-VL2)"
},
{
"author": "leeguandong",
"title": "ComfyUI_FluxLayerDiffuse",
"reference": "https://github.com/leeguandong/ComfyUI_FluxLayerDiffuse",
"files": [
"https://github.com/leeguandong/ComfyUI_FluxLayerDiffuse"
],
"install_type": "git-clone",
"description": "ComfyUI nodes to use [a/Flux-version-LayerDiffuse](https://github.com/RedAIGC/Flux-version-LayerDiffuse)"
},
{
"author": "leeguandong",
"title": "ComfyUI_Gemma3",
"reference": "https://github.com/leeguandong/ComfyUI_Gemma3",
"files": [
"https://github.com/leeguandong/ComfyUI_Gemma3"
],
"install_type": "git-clone",
"description": "ComfyUI nodes to use [a/gemma-3-27b-it](https://huggingface.co/google/gemma-3-27b-it)"
},
{
"author": "leeguandong",
"title": "ComfyUI_QWQ32B",
"reference": "https://github.com/leeguandong/ComfyUI_QWQ32B",
"files": [
"https://github.com/leeguandong/ComfyUI_QWQ32B"
],
"install_type": "git-clone",
"description": "ComfyUI nodes to use [a/QwQ-32B](https://huggingface.co/Qwen/QwQ-32B)"
},
{
"author": "lenskikh",
"title": "Propmt Worker",
@@ -15092,6 +15231,16 @@
"install_type": "git-clone",
"description": "Node and workflow profiling. Find bottlenecks in your workflows. See trends over time."
},
{
"author": "ryanontheinside",
"title": "ComfyUI_SuperResolution",
"reference": "https://github.com/ryanontheinside/ComfyUI_SuperResolution",
"files": [
"https://github.com/ryanontheinside/ComfyUI_SuperResolution"
],
"install_type": "git-clone",
"description": "A collection of high-performance neural network-based Super Resolution models for ComfyUI."
},
{
"author": "ControlAltAI",
"title": "ControlAltAI Nodes",
@@ -16801,13 +16950,13 @@
},
{
"author": "SSsnap",
"title": "ComfyUI-Ad_scheduler",
"title": "ComfyUI-Ad-scheduler",
"reference": "https://github.com/SS-snap/ComfyUI-Ad_scheduler",
"files": [
"https://github.com/SS-snap/ComfyUI-Ad_scheduler"
],
"install_type": "git-clone",
"description": "This node is used to enhance image details. We can add a latent space image and introduce any amount of noise. Then, we can start denoising at any timestep. This allows us to add more details to the image while maintaining overall consistency as much as possible."
"description": "For denoising tasks that handle noise at any time period, with the ability to add noise in post-processing to enhance details or correct structural accuracy while maintaining the original similarity. Allocating more steps allows the image to regress to an earlier stage.."
},
{
"author": "RiceRound",
@@ -18037,7 +18186,7 @@
"https://github.com/gorillaframeai/GF_nodes"
],
"install_type": "git-clone",
"description": "This custom node for ComfyUI provides advanced background removal capabilities using the briaai/RMBG-2.0 model. It is designed to seamlessly integrate into the ComfyUI environment, offering users a powerful tool for image processing tasks."
"description": "GF Remove Background 2.0"
},
{
"author": "amaozhao",
@@ -20644,6 +20793,26 @@
"install_type": "git-clone",
"description": "this repo is to capture end-to-end data, metadata, and embeddings for ComfyUI workflows, specifically HunyuanVideo to start."
},
{
"author": "fblissjr",
"title": "ComfyUI Dataset Helper & Batch Node",
"reference": "https://github.com/fblissjr/ComfyUI-DatasetHelper",
"files": [
"https://github.com/fblissjr/ComfyUI-DatasetHelper"
],
"install_type": "git-clone",
"description": "This custom node set for ComfyUI provides a DatasetBatchNode for automated, sequential processing of datasets, particularly useful for iterative training or batched image/video generation workflows."
},
{
"author": "fblissjr",
"title": "wanvideo - seamless flow",
"reference": "https://github.com/fblissjr/ComfyUI-WanSeamlessFlow",
"files": [
"https://github.com/fblissjr/ComfyUI-WanSeamlessFlow"
],
"install_type": "git-clone",
"description": "experimental wanvideo comfyui node with a singular goal - visually seamless transitions between context windows"
},
{
"author": "vincentfs",
"title": "ComfyUI-ArchiGraph",
@@ -20850,16 +21019,6 @@
"install_type": "git-clone",
"description": "This package provides custom nodes to ComfyUI to POST data to a secure API."
},
{
"author": "fblissjr",
"title": "ComfyUI Dataset Helper & Batch Node",
"reference": "https://github.com/fblissjr/ComfyUI-DatasetHelper",
"files": [
"https://github.com/fblissjr/ComfyUI-DatasetHelper"
],
"install_type": "git-clone",
"description": "This custom node set for ComfyUI provides a DatasetBatchNode for automated, sequential processing of datasets, particularly useful for iterative training or batched image/video generation workflows."
},
{
"author": "oxysoft",
"title": "ComfyUI-gowiththeflow",
@@ -21338,6 +21497,16 @@
"install_type": "git-clone",
"description": "Describe a single image or all images in a directory using models such as Janus Pro, Florence2, or JoyCaption (testing), with a particular focus on building datasets for training LoRA."
},
{
"author": "mie",
"title": "ComfyUI-MinioConnector",
"reference": "https://github.com/MieMieeeee/ComfyUI-MinioConnector",
"files": [
"https://github.com/MieMieeeee/ComfyUI-MinioConnector"
],
"install_type": "git-clone",
"description": "Provides a series of utility nodes designed for interacting with MinIO, including functionalities such as uploading and downloading files and folders, as well as creating buckets if they do not already exist."
},
{
"author": "lum3on",
"title": "LLM Polymath Chat Node",
@@ -22034,6 +22203,16 @@
"install_type": "git-clone",
"description": "A powerful ComfyUI extension node that allows you to add various exquisite artistic text effects to your images, supporting a wide range of text styles and effects."
},
{
"author": "chenpipi0807",
"title": "ComfyUI NSFW Filter",
"reference": "https://github.com/chenpipi0807/ComfyUI_NSFW_Godie",
"files": [
"https://github.com/chenpipi0807/ComfyUI_NSFW_Godie"
],
"install_type": "git-clone",
"description": "A simple and effective ComfyUI custom node for filtering inappropriate text content, automatically detecting and replacing prohibited words while preserving the original format."
},
{
"author": "ifmylove2011",
"title": "comfyui-missing-tool",
@@ -22092,7 +22271,7 @@
"https://github.com/cardenluo/ComfyUI-Apt_Preset"
],
"install_type": "git-clone",
"description": "ComfyUI-Apt_Preset is a node package designed to simplify workflows"
"description": "ComfyUI Preset Manager, supporting various preset templates and workflow management"
},
{
"author": "Holasyb918",
@@ -22136,13 +22315,13 @@
},
{
"author": "vadimcro",
"title": "VKriez Edge Preprocessors for ComfyUI",
"title": "VKRiez-Edge",
"reference": "https://github.com/vadimcro/VKRiez-Edge",
"files": [
"https://github.com/vadimcro/VKRiez-Edge"
],
"install_type": "git-clone",
"description": "A collection of advanced edge detection nodes for ComfyUI that generate high-quality edge maps for ControlNet guidance. Currently based on CPU computation, so might be a tid-bit on a slow side. If anyone is willing to refactor the code to GPU computation - Kudos!"
"description": "A collection of advanced edge detection nodes for ComfyUI that generate high-quality edge maps / contours for usage with ControlNet Canny / Anyline guidance."
},
{
"author": "Duanyll",
@@ -22234,6 +22413,16 @@
"install_type": "git-clone",
"description": "A ComfyUI extension to allow textarea elements to be scrolled over. Useful when using a trackpad in order to prevent accidental forward/back navigation (two fingers horizontally on a Mac) when scrolling around the UI."
},
{
"author": "joreyaesh",
"title": "ComfyUI Touchpad Scroll Controller",
"reference": "https://github.com/joreyaesh/comfyui_touchpad_scroll_controller.enableTouchpadScroll",
"files": [
"https://github.com/joreyaesh/comfyui_touchpad_scroll_controller.enableTouchpadScroll"
],
"install_type": "git-clone",
"description": "A ComfyUI extension that enhances touchpad navigation by redirecting two-finger scrolling over to the canvas, including over textareas. This can prevent accidental back/forward browser navigation when using horizontal touchpad gestures and provides smooth zooming and panning for Mac and other touchpad users."
},
{
"author": "ali-vilab",
"title": "ComfyUI-ACE_Plus",
@@ -22245,44 +22434,148 @@
"install_type": "git-clone",
"description": "Custom nodes for various visual generation and editing tasks using ACE_Plus FFT Model."
},
{
"author": "CY-CHENYUE",
"title": "ComfyUI-Gemini-API",
"id": "ComfyUI-Gemini-API",
"reference": "https://github.com/CY-CHENYUE/ComfyUI-Gemini-API",
"files": [
"https://github.com/CY-CHENYUE/ComfyUI-Gemini-API"
],
"description": "A custom node for ComfyUI to integrate Google Gemini API.",
"install_type": "git-clone"
},
{
"author": "chri002",
"title": "ComfyUI_depthMapOperation",
"reference": "https://github.com/chri002/ComfyUI_depthMapOperation",
"files": [
"https://github.com/chri002/ComfyUI_depthMapOperation"
],
"description": "A simple set of nodes to generate a point cloud from an image and its depth map, perform transformations and some basic operations.",
"install_type": "git-clone"
},
{
"author": "Laurent2916",
"title": "comfyui-piq",
"reference": "https://github.com/Laurent2916/comfyui-piq",
"files": [
"https://github.com/Laurent2916/comfyui-piq"
],
"description": "PIQ ComfyUI custom nodes",
"install_type": "git-clone"
},
{
"author": "thezveroboy",
"title": "ComfyUI-CSM-Nodes",
"reference": "https://github.com/thezveroboy/ComfyUI-CSM-Nodes",
"files": [
"https://github.com/thezveroboy/ComfyUI-CSM-Nodes"
],
"description": "Custom nodes for ComfyUI implementing the csm model for text-to-speech generation.",
"install_type": "git-clone"
},
{
"author": "thezveroboy",
"title": "ComfyUI-WAN-ClipSkip",
"reference": "https://github.com/thezveroboy/ComfyUI-WAN-ClipSkip",
"files": [
"https://github.com/thezveroboy/ComfyUI-WAN-ClipSkip"
],
"description": "Custom nodes for ComfyUI implementing the csm model for text-to-speech generation.",
"install_type": "git-clone"
},
{
"author": "tatookan",
"title": "comfyui_ssl_gemini_EXP",
"reference": "https://github.com/tatookan/comfyui_ssl_gemini_EXP",
"files": [
"https://github.com/tatookan/comfyui_ssl_gemini_EXP"
],
"description": "Calling gemini2.0 at comfyui . The project will continue to organize good APIs!",
"install_type": "git-clone"
},
{
"author": "atluslin",
"title": "comfyui_arcane_style_trans",
"reference": "https://github.com/atluslin/comfyui_arcane_style_trans",
"files": [
"https://github.com/atluslin/comfyui_arcane_style_trans"
],
"description": "ComfyUI's Arcane stylization plugin",
"install_type": "git-clone"
},
{
"author": "pixelworldai",
"title": "ComfyUI-AlphaFlatten",
"reference": "https://github.com/pixelworldai/ComfyUI-AlphaFlatten",
"files": [
"https://github.com/pixelworldai/ComfyUI-AlphaFlatten"
],
"description": "This node takes a batch of images with alpha channels (RGBA format) and combines them into a single image, respecting the transparency of each layer. It's particularly useful for compositing multiple masked elements (like faces) into a single image.",
"install_type": "git-clone"
},
{
"author": "CozyMantis (+ Curt-Park)",
"title": "Cozy Human Parser in pure Python",
"id": "humanparser-pure-python",
"reference": "https://github.com/Curt-Park/human-parser-comfyui-node-in-pure-python",
"files": [
"https://github.com/Curt-Park/human-parser-comfyui-node-in-pure-python"
],
"install_type": "git-clone",
"description": "It works the same as human-parser-comfyui-node but is implemented in pure Python so that it doesn't require a runtime build for InPlaceABNSync."
},
{
"author": "ComplexRobot",
"title": "ComfyUI-Simple-VFI",
"reference": "https://github.com/ComplexRobot/ComfyUI-Simple-VFI",
"files": [
"https://github.com/ComplexRobot/ComfyUI-Simple-VFI"
],
"install_type": "git-clone",
"description": "Nodes for simple frame interpolation without the use of AI. Uses standard image operations to blend frames together."
},
{
"author": "Taithrah",
"title": "Fens-Simple-Nodes",
"reference": "https://github.com/Taithrah/ComfyUI_Fens_Simple_Nodes",
"files": [
"https://github.com/Taithrah/ComfyUI_Fens_Simple_Nodes"
],
"install_type": "git-clone",
"description": "Simple nodes for ComfyUI"
},
{
"author": "Immac",
"title": "ComfyUI Core Video Nodes",
"reference": "https://github.com/Immac/ComfyUI-CoreVideoMocks",
"files": [
"https://github.com/Immac/ComfyUI-CoreVideoMocks"
],
"install_type": "git-clone",
"description": "A mock of a possible implementation of for ComfyUI Core Video Nodes."
},
{
"author": "kuo6",
"title": "ComfyUI Equirectangular Tools",
"reference": "https://github.com/kukuo6666/ComfyUI-Equirect",
"files": [
"https://github.com/kukuo6666/ComfyUI-Equirect"
],
"install_type": "git-clone",
"description": "Tools for processing equirectangular images, supporting conversion from equirectangular format to cubemap."
},
{
"author": "jonstreeter",
"title": "Comfyui-PySceneDetect",
"reference": "https://github.com/jonstreeter/Comfyui-PySceneDetect",
"files": [
"https://github.com/jonstreeter/Comfyui-PySceneDetect"
],
"install_type": "git-clone",
"description": "NODES: PySceneDetect Video Processor"
},

View File

File diff suppressed because it is too large Load Diff

View File

File diff suppressed because it is too large Load Diff

View File

@@ -43,7 +43,7 @@ import manager_downloader
from node_package import InstalledNodePackage
version_code = [3, 31, 1]
version_code = [3, 31, 6]
version_str = f"V{version_code[0]}.{version_code[1]}" + (f'.{version_code[2]}' if len(version_code) > 2 else '')
@@ -768,6 +768,9 @@ class UnifiedManager:
@staticmethod
async def load_nightly(channel, mode):
if channel is None:
return {}
res = {}
channel_url = normalize_channel(channel)
@@ -798,8 +801,9 @@ class UnifiedManager:
return res
async def get_custom_nodes(self, channel, mode):
# default_channel = normalize_channel('default')
# cache = self.custom_node_map_cache.get((default_channel, mode)) # CNR/nightly should always be based on the default channel.
if channel is None and mode is None:
channel = 'default'
mode = 'cache'
channel = normalize_channel(channel)
cache = self.custom_node_map_cache.get((channel, mode)) # CNR/nightly should always be based on the default channel.
@@ -808,7 +812,6 @@ class UnifiedManager:
return cache
channel = normalize_channel(channel)
print(f"nightly_channel: {channel}/{mode}")
nodes = await self.load_nightly(channel, mode)
res = {}
@@ -889,14 +892,6 @@ class UnifiedManager:
return True
def reserve_migration(self, moves):
script_path = os.path.join(manager_startup_script_path, "install-scripts.txt")
with open(script_path, "a") as file:
obj = ["", "#LAZY-MIGRATION", moves]
file.write(f"{obj}\n")
return True
def unified_fix(self, node_id, version_spec, instant_execution=False, no_deps=False):
"""
fix dependencies
@@ -1630,7 +1625,6 @@ def write_config():
'model_download_by_agent': get_config()['model_download_by_agent'],
'downgrade_blacklist': get_config()['downgrade_blacklist'],
'security_level': get_config()['security_level'],
'skip_migration_check': get_config()['skip_migration_check'],
'always_lazy_install': get_config()['always_lazy_install'],
'network_mode': get_config()['network_mode'],
'db_mode': get_config()['db_mode'],
@@ -1669,7 +1663,6 @@ def read_config():
'windows_selector_event_loop_policy': get_bool('windows_selector_event_loop_policy', False),
'model_download_by_agent': get_bool('model_download_by_agent', False),
'downgrade_blacklist': default_conf.get('downgrade_blacklist', '').lower(),
'skip_migration_check': get_bool('skip_migration_check', False),
'always_lazy_install': get_bool('always_lazy_install', False),
'network_mode': default_conf.get('network_mode', 'public').lower(),
'security_level': default_conf.get('security_level', 'normal').lower(),
@@ -1693,7 +1686,6 @@ def read_config():
'windows_selector_event_loop_policy': False,
'model_download_by_agent': False,
'downgrade_blacklist': '',
'skip_migration_check': False,
'always_lazy_install': False,
'network_mode': 'public', # public | private | offline
'security_level': 'normal', # strong | normal | normal- | weak
@@ -2098,7 +2090,7 @@ async def gitclone_install(url, instant_execution=False, msg_prefix='', no_deps=
cnr = unified_manager.get_cnr_by_repo(url)
if cnr:
cnr_id = cnr['id']
return await unified_manager.install_by_id(cnr_id, version_spec='nightly', channel='default')
return await unified_manager.install_by_id(cnr_id, version_spec='nightly', channel='default', mode='cache')
else:
repo_name = os.path.splitext(os.path.basename(url))[0]
@@ -3026,6 +3018,9 @@ async def restore_snapshot(snapshot_path, git_helper_extras=None):
enabled_repos = []
disabled_repos = []
skip_node_packs = []
switched_node_packs = []
installed_node_packs = []
failed = []
await unified_manager.reload('cache')
await unified_manager.get_custom_nodes('default', 'cache')
@@ -3071,8 +3066,13 @@ async def restore_snapshot(snapshot_path, git_helper_extras=None):
disabled_repos.append(x)
for x in todo_checkout:
unified_manager.cnr_switch_version(x[0], x[1], instant_execution=True, no_deps=True, return_postinstall=False)
checkout_repos.append(x[1])
ps = unified_manager.cnr_switch_version(x[0], x[1], instant_execution=True, no_deps=True, return_postinstall=False)
if ps.action == 'switch-cnr' and ps.result:
switched_node_packs.append(f"{x[0]}@{x[1]}")
elif ps.action == 'skip':
skip_node_packs.append(f"{x[0]}@{x[1]}")
elif not ps.result:
failed.append(f"{x[0]}@{x[1]}")
# install listed cnr nodes
for k, v in cnr_info.items():
@@ -3080,7 +3080,9 @@ async def restore_snapshot(snapshot_path, git_helper_extras=None):
continue
ps = await unified_manager.install_by_id(k, version_spec=v, instant_execution=True, return_postinstall=True)
cloned_repos.append(k)
if ps.action == 'install-cnr' and ps.result:
installed_node_packs.append(f"{k}@{v}")
if ps is not None and ps.result:
if hasattr(ps, 'postinstall'):
postinstalls.append(ps.postinstall)
@@ -3138,40 +3140,41 @@ async def restore_snapshot(snapshot_path, git_helper_extras=None):
disabled_repos.append(x)
for x in todo_enable:
res = unified_manager.unified_enable(x, 'nightly')
res = unified_manager.unified_enable(x[0], 'nightly')
is_switched = False
if res and res.target:
is_switched = repo_switch_commit(res.target, x[1])
if is_switched:
checkout_repos.append(x)
checkout_repos.append(f"{x[0]}@{x[1]}")
else:
enabled_repos.append(x)
enabled_repos.append(x[0])
for x in todo_checkout:
is_switched = repo_switch_commit(x[0], x[1])
if is_switched:
checkout_repos.append(x)
else:
skip_node_packs.append(x[0])
checkout_repos.append(f"{x[0]}@{x[1]}")
for x in git_info.keys():
normalized_url = git_utils.normalize_url(x)
cnr = unified_manager.repo_cnr_map.get(normalized_url)
if cnr is not None:
pack_id = cnr['id']
await unified_manager.install_by_id(pack_id, 'nightly', instant_execution=True, no_deps=False, return_postinstall=False)
cloned_repos.append(pack_id)
res = await unified_manager.install_by_id(pack_id, 'nightly', instant_execution=True, no_deps=False, return_postinstall=False)
if res.action == 'install-git' and res.result:
cloned_repos.append(pack_id)
elif res.action == 'skip':
skip_node_packs.append(pack_id)
elif not res.result:
failed.append(pack_id)
processed_urls.append(x)
for x in processed_urls:
if x in git_info:
del git_info[x]
# remained nightly will be installed and migrated
# for unknown restore
todo_disable = []
todo_enable = []
@@ -3218,15 +3221,15 @@ async def restore_snapshot(snapshot_path, git_helper_extras=None):
is_switched = repo_switch_commit(res.target, x[1])
if is_switched:
checkout_repos.append(x)
checkout_repos.append(f"{x[0]}@{x[1]}")
else:
enabled_repos.append(x)
enabled_repos.append(x[0])
for x in todo_checkout:
is_switched = repo_switch_commit(x[0], x[1])
if is_switched:
checkout_repos.append(x)
checkout_repos.append(f"{x[0]}@{x[1]}")
else:
skip_node_packs.append(x[0])
@@ -3243,53 +3246,28 @@ async def restore_snapshot(snapshot_path, git_helper_extras=None):
unified_manager.repo_install(repo_url, to_path, instant_execution=True, no_deps=False, return_postinstall=False)
cloned_repos.append(repo_name)
# reload
await unified_manager.migrate_unmanaged_nodes()
# print summary
for x in cloned_repos:
print(f"[ INSTALLED ] {x}")
for x in installed_node_packs:
print(f"[ INSTALLED ] {x}")
for x in checkout_repos:
print(f"[ CHECKOUT ] {x}")
for x in switched_node_packs:
print(f"[ SWITCHED ] {x}")
for x in enabled_repos:
print(f"[ ENABLED ] {x}")
for x in disabled_repos:
print(f"[ DISABLED ] {x}")
for x in skip_node_packs:
print(f"[ SKIPPED ] {x}")
print(f"[ SKIPPED ] {x}")
for x in failed:
print(f"[ FAILED ] {x}")
# if is_failed:
# print("[bold red]ERROR: Failed to restore snapshot.[/bold red]")
# check need to migrate
need_to_migrate = False
async def check_need_to_migrate():
global need_to_migrate
await unified_manager.reload('cache')
await unified_manager.load_nightly(channel='default', mode='cache')
legacy_custom_nodes = []
for x in unified_manager.active_nodes.values():
if x[0] == 'nightly' and not x[1].endswith('@nightly'):
legacy_custom_nodes.append(x[1])
for x in unified_manager.nightly_inactive_nodes.values():
if not x.endswith('@nightly'):
legacy_custom_nodes.append(x)
if len(legacy_custom_nodes) > 0:
print("\n--------------------- ComfyUI-Manager migration notice --------------------")
print("The following custom nodes were installed using the old management method and require migration:\n")
print("\n".join(legacy_custom_nodes))
print("---------------------------------------------------------------------------\n")
need_to_migrate = True
def get_comfyui_versions(repo=None):
if repo is None:
repo = git.Repo(comfy_path)

View File

@@ -273,7 +273,7 @@ import zipfile
import urllib.request
def get_model_dir(data, show_log=False) -> str | None:
def get_model_dir(data, show_log=False):
if 'download_model_base' in folder_paths.folder_names_and_paths:
models_base = folder_paths.folder_names_and_paths['download_model_base'][0][0]
else:
@@ -1748,11 +1748,6 @@ async def default_cache_update():
logging.info("[ComfyUI-Manager] All startup tasks have been completed.")
# NOTE: hide migration button temporarily.
# if not core.get_config()['skip_migration_check']:
# await core.check_need_to_migrate()
# else:
# logging.info("[ComfyUI-Manager] Migration check is skipped...")
threading.Thread(target=lambda: asyncio.run(default_cache_update())).start()

View File

@@ -439,10 +439,12 @@ class PIPFixer:
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")
if front_line is None:
logging.info("[ComfyUI-Manager] Skipped fixing the 'comfyui-frontend-package' dependency because the ComfyUI is outdated.")
else:
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)

View File

@@ -13,7 +13,7 @@ import {
import { OpenArtShareDialog } from "./comfyui-share-openart.js";
import {
free_models, install_pip, install_via_git_url, manager_instance,
rebootAPI, migrateAPI, setManagerInstance, show_message, customAlert, customPrompt,
rebootAPI, setManagerInstance, show_message, customAlert, customPrompt,
infoToast, showTerminal, setNeedRestart
} from "./common.js";
import { ComponentBuilderDialog, getPureName, load_components, set_component_policy } from "./components-manager.js";
@@ -946,28 +946,6 @@ class ManagerMenuDialog extends ComfyDialog {
restart_stop_button,
];
let migration_btn =
$el("button.cm-button-orange", {
type: "button",
textContent: "Migrate to New Node System",
onclick: () => migrateAPI()
});
migration_btn.style.display = 'none';
res.push(migration_btn);
api.fetchApi('/manager/need_to_migrate')
.then(response => response.text())
.then(text => {
if (text === 'True') {
migration_btn.style.display = 'block';
}
})
.catch(error => {
console.error('Error checking migration status:', error);
});
return res;
}

View File

@@ -182,23 +182,6 @@ export function rebootAPI() {
}
export async function migrateAPI() {
let confirmed = await customConfirm("When performing a migration, existing installed custom nodes will be renamed and the server will be restarted. Are you sure you want to apply this?\n\n(If you don't perform the migration, ComfyUI-Manager's start-up time will be longer each time due to re-checking during startup.)")
if (confirmed) {
try {
await api.fetchApi("/manager/migrate_unmanaged_nodes");
api.fetchApi("/manager/reboot");
}
catch(exception) {
}
return true;
}
return false;
}
export var manager_instance = null;
export function setManagerInstance(obj) {

View File

@@ -11,6 +11,86 @@
{
"author": "Solankimayursinh",
"title": "PMSnodes",
"reference": "https://github.com/Solankimayursinh/PMSnodes",
"files": [
"https://github.com/Solankimayursinh/PMSnodes"
],
"install_type": "git-clone",
"description": "A custom nodes for ComfyUI to Load audio in Base64 format and Send Audio to Websocket in Base64 Format for creating API of Audio related AI\nNOTE: The files in the repo are not organized."
},
{
"author": "rhinoflavored",
"title": "comfyui_QT",
"reference": "https://github.com/rhinoflavored/comfyui_QT",
"files": [
"https://github.com/rhinoflavored/comfyui_QT"
],
"install_type": "git-clone",
"description": "bunch of image manipulation nodes....\nNOTE: The files in the repo are not organized."
},
{
"author": "ricklove",
"title": "ComfyUI-AutoSeg-SAM2",
"reference": "https://github.com/ricklove/ComfyUI-AutoSeg-SAM2",
"files": [
"https://github.com/ricklove/ComfyUI-AutoSeg-SAM2"
],
"install_type": "git-clone",
"description": "NODES: AutoSeg-SAM2 Batch Segmentation"
},
{
"author": "JoeAu",
"title": "ComfyUI-PythonNode [UNSAFE]",
"reference": "https://github.com/JoeAu/ComfyUI-PythonNode",
"files": [
"https://github.com/JoeAu/ComfyUI-PythonNode"
],
"install_type": "git-clone",
"description": "A custom ComfyUI node that allows users to execute arbitrary Python code with a single input (value) and output (result), enabling flexible processing of the input value using any Python code before assigning the final result to result. It also captures print() output and exceptions for debugging.[w/This node is an unsafe node that includes the capability to execute arbitrary python script.]"
},
{
"author": "smthemex",
"title": "ComfyUI_GPT_SoVITS_Lite",
"reference": "https://github.com/smthemex/ComfyUI_GPT_SoVITS_Lite",
"files": [
"https://github.com/smthemex/ComfyUI_GPT_SoVITS_Lite"
],
"install_type": "git-clone",
"description": "[a/GPT_SoVITS](https://github.com/RVC-Boss/GPT-SoVITS) infer only for ComfyUI users\nNOTE: The files in the repo are not organized."
},
{
"author": "Nambi24",
"title": "ComfyUI-Save_Image",
"reference": "https://github.com/Nambi24/ComfyUI-Save_Image",
"files": [
"https://github.com/Nambi24/ComfyUI-Save_Image"
],
"description": "NODES: Save Image With Subfolder, Extract Last Path Component\nNOTE: The files in the repo are not organized.",
"install_type": "git-clone"
},
{
"author": "sugarkwork",
"title": "comfyui_image_crop",
"reference": "https://github.com/sugarkwork/comfyui_image_crop",
"files": [
"https://github.com/sugarkwork/comfyui_image_crop"
],
"description": "NODES: CropTransparent, RestoreCrop, ExpandMultiple, CropReapply",
"install_type": "git-clone"
},
{
"author": "AkiEvansDev",
"title": "ComfyUI-Tools",
"reference": "https://github.com/AkiEvansDev/ComfyUI-Tools",
"files": [
"https://github.com/AkiEvansDev/ComfyUI-Tools"
],
"install_type": "git-clone",
"description": "Custom nodes for basic actions."
},
{
"author": "silveroxides",
"title": "ComfyUI-ModelUtils [WIP]",

View File

@@ -359,6 +359,98 @@
"title_aux": "ComfyUI-Upscayl"
}
],
"https://github.com/AkiEvansDev/ComfyUI-Tools": [
[
"AE.AnySwitch",
"AE.AnyTypeSwitch",
"AE.BRIARemBG",
"AE.BRIARemBGAdvanced",
"AE.ChangeSamplerConfig",
"AE.CheckpointList",
"AE.CheckpointLoader",
"AE.CompareFloat",
"AE.CompareInt",
"AE.ControlNetApplyWithConfig",
"AE.ControlNetConfig",
"AE.DisplayAny",
"AE.ExtractControlNetConfig",
"AE.ExtractHiresFixConfig",
"AE.ExtractImg2ImgConfig",
"AE.ExtractOutpaintConfig",
"AE.ExtractSamplerConfig",
"AE.Float",
"AE.FloatList",
"AE.FloatSwitch",
"AE.FloatToInt",
"AE.GaussianBlurMask",
"AE.GetImageSize",
"AE.GetLatentSize",
"AE.GroupsMuter",
"AE.HiresFixConfig",
"AE.ImageAdjustment",
"AE.ImageBlank",
"AE.ImageBlendMask",
"AE.ImageBlendMode",
"AE.ImageCannyFilter",
"AE.ImageDragonFilter",
"AE.ImageHighPassFilter",
"AE.ImageLevels",
"AE.ImageLucySharpen",
"AE.ImagePixelate",
"AE.ImagePowerNoise",
"AE.ImageStyleFilter",
"AE.Img2ImgConfig",
"AE.InpaintWithModel",
"AE.Int",
"AE.IntList",
"AE.IntSwitch",
"AE.IntToFloat",
"AE.KSamplerHiresFixWithConfig",
"AE.KSamplerImg2ImgWithConfig",
"AE.KSamplerInpaintWithConfig",
"AE.KSamplerOutpaintWithConfig",
"AE.KSamplerOutpaintWithConfigAndImage",
"AE.KSamplerWithConfig",
"AE.LoadImageFromPath",
"AE.LoadInpaintModel",
"AE.LoraLoader",
"AE.LorasList",
"AE.LorasLoader",
"AE.MathFloat",
"AE.MathInt",
"AE.OutpaintConfig",
"AE.OutpaintWithModel",
"AE.OutpaintWithModelAndConfig",
"AE.Range",
"AE.RangeList",
"AE.SDXLConfig",
"AE.SDXLPrompt",
"AE.SDXLPromptWithHires",
"AE.SDXLRegionalPrompt",
"AE.SDXLRegionalPromptWithHires",
"AE.SamplerConfig",
"AE.SamplerList",
"AE.SaveImage",
"AE.SchedulerList",
"AE.Seed",
"AE.String",
"AE.StringConcat",
"AE.StringEquals",
"AE.StringLength",
"AE.StringList",
"AE.StringReplace",
"AE.StringSwitch",
"AE.Text",
"AE.ToString",
"AE.ToStringConcat",
"AE.UpscaleLatentBy",
"AE.VAEEncodeInpaintConditioning",
"AE.XYRange"
],
{
"title_aux": "ComfyUI-Tools"
}
],
"https://github.com/AlexXi19/ComfyUI-OpenAINode": [
[
"ImageWithPrompt",
@@ -1130,29 +1222,39 @@
"https://github.com/KurtHokke/ComfyUI_KurtHokke-Nodes": [
[
"AIO_Tuner_Pipe",
"ApplyCondsExtraOpts",
"BashScriptNode",
"BooleanFromPipe",
"BooleanToPipe",
"COND_ExtraOpts",
"COND_ExtraOpts_2",
"COND_SET_STRENGTH_ExtraOpts",
"ChainTextEncode",
"CkptPipe",
"CompareTorch",
"DynamicThresholding",
"DynamicThresholdingBasic",
"EmptyLatentSize",
"EmptyLatentSize64",
"ExecutePythonNode",
"ExpMath",
"ExpMathDual",
"ExpMathQuad",
"InspectNode",
"LoadUnetAndClip",
"LoraFluxParams",
"MergeExtraOpts",
"ModelPipe1",
"ModelPipe2",
"NoModel_CkptLoader",
"NoNegExtraOpts",
"Node_BOOL",
"Node_Float",
"Node_INT",
"Node_RandomRange",
"Node_String",
"Node_StringMultiline",
"SEED_ExtraOpts",
"SamplerCustomAdvanced_Pipe",
"SamplerSel",
"SchedulerSel",
@@ -1160,9 +1262,12 @@
"UnetClipLoraLoader",
"UnetClipLoraLoaderBasic",
"VAE_ExtraOpts",
"debug_object",
"ViewExtraOpts",
"batchsize_ExtraOpts",
"get_lora_metadata",
"mycombine",
"re_sub_str",
"splitcond",
"str_str",
"str_str_str_str"
],
@@ -1442,6 +1547,15 @@
"title_aux": "ComfyUI-tools-by-dong [UNSAFE]"
}
],
"https://github.com/Nambi24/ComfyUI-Save_Image": [
[
"ExtractLastPathComponent",
"SaveImageNode"
],
{
"title_aux": "ComfyUI-Save_Image"
}
],
"https://github.com/Northerner1/ComfyUI_North_Noise": [
[
"North_Noise"
@@ -1702,7 +1816,6 @@
"Test Node (Shinsplat)",
"Text To Tokens (Shinsplat)",
"Text To Tokens SD3 (Shinsplat)",
"Upscale WEBP (Shinsplat)",
"Variables (Shinsplat)"
],
{
@@ -1736,6 +1849,16 @@
"title_aux": "ComfyUI-PIL"
}
],
"https://github.com/Solankimayursinh/PMSnodes": [
[
"InputAnalyzer",
"LoadBase64Audio",
"PMSSendAudio"
],
{
"title_aux": "PMSnodes"
}
],
"https://github.com/Soppatorsk/comfyui_img_to_ascii": [
[
"Img_to_ASCII"
@@ -2132,6 +2255,7 @@
"https://github.com/ammahmoudi/ComfyUI-Legendary-Nodes": [
[
"Legendary Dataset Saver",
"Legendary Image URL Loader",
"Legendary Lora URL Loader"
],
{
@@ -3274,6 +3398,7 @@
],
"https://github.com/grinlau18/ComfyUI_XISER_Nodes": [
[
"XIS_CropImage",
"XIS_Float_Slider",
"XIS_FromListGet1Color",
"XIS_FromListGet1Cond",
@@ -3285,10 +3410,12 @@
"XIS_FromListGet1Model",
"XIS_FromListGet1String",
"XIS_INT_Slider",
"XIS_IfDataIsNone",
"XIS_ImageMaskMirror",
"XIS_InvertMask",
"XIS_IsThereAnyData",
"XIS_PromptsWithSwitches",
"XIS_ReorderImageMaskGroups",
"XIS_ResizeImageOrMask",
"XIS_ResizeToDivisible"
],
@@ -4057,6 +4184,7 @@
"WanVideoFlowEdit",
"WanVideoImageClipEncode",
"WanVideoLatentPreview",
"WanVideoLoopArgs",
"WanVideoLoraBlockEdit",
"WanVideoLoraSelect",
"WanVideoModelLoader",
@@ -4065,6 +4193,7 @@
"WanVideoTeaCache",
"WanVideoTextEmbedBridge",
"WanVideoTextEncode",
"WanVideoTinyVAELoader",
"WanVideoTorchCompileSettings",
"WanVideoVAELoader",
"WanVideoVRAMManagement"
@@ -4435,6 +4564,7 @@
"polymath_SaveAbsolute",
"polymath_chat",
"polymath_concept_eraser",
"polymath_dsd_sampler",
"polymath_helper",
"polymath_scraper"
],
@@ -4842,10 +4972,13 @@
"ClusterBroadcastTensor",
"ClusterExecuteCurrentWorkflow",
"ClusterExecuteWorkflow",
"ClusterFanInImages",
"ClusterFanOutImage",
"ClusterFanOutLatent",
"ClusterFanOutMask",
"ClusterFinallyFree",
"ClusterFlattenBatchedImageList",
"ClusterFreeNow",
"ClusterGatherImages",
"ClusterGatherLatents",
"ClusterGatherMasks",
@@ -5091,6 +5224,84 @@
"title_aux": "ComfyUI-ODE"
}
],
"https://github.com/rhinoflavored/comfyui_QT": [
[
"CSVDataMatcher",
"QTAutoCropByNPS",
"QTExcelImageReader",
"QTExcelReader",
"QTRandomSelectString",
"QTStringWrappingByNumber",
"QT_Alpha_Yaxis_Node",
"QT_AntiAliasing_Node",
"QT_Batch_Anything_Node",
"QT_Center_Rotation",
"QT_Character_Height_Difference",
"QT_Character_Size_Node",
"QT_Color_Image_Loop",
"QT_Content_Location_Node",
"QT_Crop_Alpha",
"QT_Crop_Alpha_V2",
"QT_Curves_Node",
"QT_Dictionary_Node",
"QT_Elements_Into_List_Node",
"QT_Float_To_Int",
"QT_Image_Array",
"QT_Image_Array_Circle",
"QT_Image_Array_Rectangle",
"QT_Image_Overlay",
"QT_Image_Overlay_BOOLEAN",
"QT_Image_Overlay_Rotation",
"QT_Image_Overlay_V2",
"QT_Image_Overlay_V3",
"QT_Image_Sorting_Node",
"QT_Image_Upscale_And_Crop_Node",
"QT_Image_Upscale_And_Crop_Node_V2",
"QT_Image_Upscale_And_Crop_Node_V3",
"QT_Image_Upscale_Node",
"QT_Image_Vision_Center_Node",
"QT_Join_Image_List_Node",
"QT_Line_Break",
"QT_Line_Break_V2",
"QT_List_Length",
"QT_List_Picker",
"QT_List_To_String",
"QT_Mask_Mix_Node",
"QT_Merge_Into_List_Node",
"QT_Pageturn_Node",
"QT_Pattern_Fill",
"QT_Piecewise_Function_Node",
"QT_Polar_Coordinate_Conversion_Node",
"QT_Rounded_Corner",
"QT_SUPIR_Upscale",
"QT_Simple_Text_Image_V2",
"QT_Sorting_Node",
"QT_Split_List_Node",
"QT_Split_List_Node_V2",
"QT_Split_Mask_Node",
"QT_Split_String",
"QT_String_Horizontal_To_Vertical",
"QT_String_To_List",
"QT_Text_Input_Switch_Node",
"QT_Text_Overlay_V2",
"QT_Text_To_Bool_Node",
"QT_Tilt_Transform",
"QT_Translucent_Node",
"QT_Vertical_Text_Overlay",
"QT_Video_Combine_Node"
],
{
"title_aux": "comfyui_QT"
}
],
"https://github.com/ricklove/ComfyUI-AutoSeg-SAM2": [
[
"AutoSegSAM2Node"
],
{
"title_aux": "ComfyUI-AutoSeg-SAM2"
}
],
"https://github.com/rishipandey125/ComfyUI-FramePacking": [
[
"Add Grid Boundaries",
@@ -5226,8 +5437,8 @@
{
"author": "shinich39",
"description": "Javascript code will run when an event fires.",
"nickname": "event-handler",
"title": "event-handler",
"nickname": "comfyui-event-handler",
"title": "comfyui-event-handler",
"title_aux": "comfyui-event-handler [USAFE]"
}
],
@@ -5266,6 +5477,15 @@
"title_aux": "ComfyUI LLM Prompt Enhancer [WIP]"
}
],
"https://github.com/smthemex/ComfyUI_GPT_SoVITS_Lite": [
[
"GPT_SoVITS_LoadModel",
"GPT_SoVITS_Sampler"
],
{
"title_aux": "ComfyUI_GPT_SoVITS_Lite"
}
],
"https://github.com/smthemex/ComfyUI_MangaNinjia": [
[
"MangaNinjiaLoader",
@@ -5379,6 +5599,17 @@
"title_aux": "ComfyUI-Terminal [UNSAFE]"
}
],
"https://github.com/sugarkwork/comfyui_image_crop": [
[
"CropReapply",
"CropTransparent",
"ExpandMultiple",
"RestoreCrop"
],
{
"title_aux": "comfyui_image_crop"
}
],
"https://github.com/sugarkwork/comfyui_psd": [
[
"Convert PSD to Image",
@@ -5450,7 +5681,9 @@
"https://github.com/thedivergentai/divergent_nodes": [
[
"CLIPTokenCounter",
"DolphinVisionNode"
"DataStoreNode",
"Text Line Reader",
"UTF8EncoderNode"
],
{
"title_aux": "Divergent Nodes [WIP]"
@@ -5458,6 +5691,7 @@
],
"https://github.com/thisiseddy-ab/ComfyUI-Edins-Ultimate-Pack": [
[
"EUP - Custom Aspect Ratio",
"EUP - Iterative Latent Upscaler",
"EUP - Latent Merger",
"EUP - Latent Tiler",

View File

File diff suppressed because it is too large Load Diff

View File

@@ -11,6 +11,17 @@
{
"author": "Makki_Shizu",
"title": "ComfyUI-SaveAnimatedGIF [DEPRECATED]",
"id": "SaveAnimatedGIF",
"reference": "https://github.com/MakkiShizu/ComfyUI-SaveAnimatedGIF",
"files": [
"https://github.com/MakkiShizu/ComfyUI-SaveAnimatedGIF"
],
"install_type": "git-clone",
"description": "Save animated GIF format nodes in ComfyUI"
},
{
"author": "l1yongch1",
"title": "ComfyUI_PhiCaption [REMOVED]",

View File

@@ -8,6 +8,338 @@
"description": "If you see this message, your ComfyUI-Manager is outdated.\nRecent channel provides only the list of the latest nodes. If you want to find the complete node list, please go to the Default channel.\nMaking LoRA has never been easier!"
},
{
"author": "yuvraj108c",
"title": "ComfyUI Thera",
"reference": "https://github.com/yuvraj108c/ComfyUI-Thera",
"files": [
"https://github.com/yuvraj108c/ComfyUI-Thera"
],
"install_type": "git-clone",
"description": "This project is an unofficial ComfyUI implementation of [a/Thera](https://github.com/prs-eth/thera) (Aliasing-Free Arbitrary-Scale Super-Resolution with Neural Heat Fields)"
},
{
"author": "kuo6",
"title": "ComfyUI Equirectangular Tools",
"reference": "https://github.com/kukuo6666/ComfyUI-Equirect",
"files": [
"https://github.com/kukuo6666/ComfyUI-Equirect"
],
"install_type": "git-clone",
"description": "Tools for processing equirectangular images, supporting conversion from equirectangular format to cubemap."
},
{
"author": "jonstreeter",
"title": "Comfyui-PySceneDetect",
"reference": "https://github.com/jonstreeter/Comfyui-PySceneDetect",
"files": [
"https://github.com/jonstreeter/Comfyui-PySceneDetect"
],
"install_type": "git-clone",
"description": "NODES: PySceneDetect Video Processor"
},
{
"author": "CozyMantis (+ Curt-Park)",
"title": "Cozy Human Parser in pure Python",
"id": "humanparser-pure-python",
"reference": "https://github.com/Curt-Park/human-parser-comfyui-node-in-pure-python",
"files": [
"https://github.com/Curt-Park/human-parser-comfyui-node-in-pure-python"
],
"install_type": "git-clone",
"description": "It works the same as human-parser-comfyui-node but is implemented in pure Python so that it doesn't require a runtime build for InPlaceABNSync."
},
{
"author": "1038lab",
"title": "Comfyui-Spark-TTS",
"reference": "https://github.com/1038lab/ComfyUI-SparkTTS",
"files": [
"https://github.com/1038lab/ComfyUI-SparkTTS"
],
"install_type": "git-clone",
"description": "ComfyUI-SparkTTS is a custom ComfyUI node implementation of SparkTTS, an advanced text-to-speech system that harnesses the power of large language models (LLMs) to generate highly accurate and natural-sounding speech."
},
{
"author": "fblissjr",
"title": "wanvideo - seamless flow",
"reference": "https://github.com/fblissjr/ComfyUI-WanSeamlessFlow",
"files": [
"https://github.com/fblissjr/ComfyUI-WanSeamlessFlow"
],
"install_type": "git-clone",
"description": "experimental wanvideo comfyui node with a singular goal - visually seamless transitions between context windows"
},
{
"author": "fofr",
"title": "ComfyUI-Basic-Auth",
"reference": "https://github.com/fofr/comfyui-basic-auth",
"files": [
"https://github.com/fofr/comfyui-basic-auth"
],
"install_type": "git-clone",
"description": "A basic auth middleware for ComfyUI"
},
{
"author": "ryanontheinside",
"title": "ComfyUI_SuperResolution",
"reference": "https://github.com/ryanontheinside/ComfyUI_SuperResolution",
"files": [
"https://github.com/ryanontheinside/ComfyUI_SuperResolution"
],
"install_type": "git-clone",
"description": "A collection of high-performance neural network-based Super Resolution models for ComfyUI."
},
{
"author": "thezveroboy",
"title": "ComfyUI-WAN-ClipSkip",
"reference": "https://github.com/thezveroboy/ComfyUI-WAN-ClipSkip",
"files": [
"https://github.com/thezveroboy/ComfyUI-WAN-ClipSkip"
],
"description": "Custom nodes for ComfyUI implementing the csm model for text-to-speech generation.",
"install_type": "git-clone"
},
{
"author": "ShmuelRonen",
"title": "ComfyUI-PixArt_XL",
"reference": "https://github.com/ShmuelRonen/ComfyUI-PixArt_XL",
"files": [
"https://github.com/ShmuelRonen/ComfyUI-PixArt_XL"
],
"install_type": "git-clone",
"description": "A ComfyUI extension that integrates PixArt-Alpha models directly into ComfyUI with advanced memory management."
},
{
"author": "leeguandong",
"title": "ComfyUI_QWQ32B",
"reference": "https://github.com/leeguandong/ComfyUI_QWQ32B",
"files": [
"https://github.com/leeguandong/ComfyUI_QWQ32B"
],
"install_type": "git-clone",
"description": "ComfyUI nodes to use [a/QwQ-32B](https://huggingface.co/Qwen/QwQ-32B)"
},
{
"author": "ComplexRobot",
"title": "ComfyUI-Simple-VFI",
"reference": "https://github.com/ComplexRobot/ComfyUI-Simple-VFI",
"files": [
"https://github.com/ComplexRobot/ComfyUI-Simple-VFI"
],
"install_type": "git-clone",
"description": "Nodes for simple frame interpolation without the use of AI. Uses standard image operations to blend frames together."
},
{
"author": "Taithrah",
"title": "Fens-Simple-Nodes",
"reference": "https://github.com/Taithrah/ComfyUI_Fens_Simple_Nodes",
"files": [
"https://github.com/Taithrah/ComfyUI_Fens_Simple_Nodes"
],
"install_type": "git-clone",
"description": "Simple nodes for ComfyUI"
},
{
"author": "Immac",
"title": "ComfyUI Core Video Nodes",
"reference": "https://github.com/Immac/ComfyUI-CoreVideoMocks",
"files": [
"https://github.com/Immac/ComfyUI-CoreVideoMocks"
],
"install_type": "git-clone",
"description": "A mock of a possible implementation of for ComfyUI Core Video Nodes."
},
{
"author": "joreyaesh",
"title": "ComfyUI Touchpad Scroll Controller",
"reference": "https://github.com/joreyaesh/comfyui_touchpad_scroll_controller.enableTouchpadScroll",
"files": [
"https://github.com/joreyaesh/comfyui_touchpad_scroll_controller.enableTouchpadScroll"
],
"install_type": "git-clone",
"description": "A ComfyUI extension that enhances touchpad navigation by redirecting two-finger scrolling over to the canvas, including over textareas. This can prevent accidental back/forward browser navigation when using horizontal touchpad gestures and provides smooth zooming and panning for Mac and other touchpad users."
},
{
"author": "impactframes",
"title": "IF_VideoPrompts",
"id": "impactframes-videoprompts",
"reference": "https://github.com/if-ai/ComfyUI-IF_VideoPrompts",
"files": [
"https://github.com/if-ai/ComfyUI-IF_VideoPrompts"
],
"install_type": "git-clone",
"description": "ComfyUI extension for video-based prompting and processing with support for various models and video processing capabilities"
},
{
"author": "impactframes",
"title": "IF_LLM",
"id": "impactframes-llm",
"reference": "https://github.com/if-ai/ComfyUI-IF_LLM",
"files": [
"https://github.com/if-ai/ComfyUI-IF_LLM"
],
"install_type": "git-clone",
"description": "Run Local and API LLMs, Features Conditioning manipulation via Omost, supports Ollama, LlamaCPP LMstudio, Koboldcpp, TextGen, Transformers or via APIs Anthropic, Groq, OpenAI, Google Gemini, Mistral, xAI and create your own charcters assistants (SystemPrompts) with custom presets and muchmore"
},
{
"author": "impactframes",
"title": "IF_AI_LoadImages",
"id": "impactframes-loadimages",
"reference": "https://github.com/if-ai/ComfyUI_IF_AI_LoadImages",
"files": [
"https://github.com/if-ai/ComfyUI_IF_AI_LoadImages"
],
"install_type": "git-clone",
"description": "It Load Images with subfolders form arbitrary folders previous on node outputs lists- convinient selection via file browser"
},
{
"author": "ostris",
"title": "Flex.1 tools",
"id": "ostris",
"reference": "https://github.com/ostris/ComfyUI-FlexTools",
"files": [
"https://github.com/ostris/ComfyUI-FlexTools"
],
"install_type": "git-clone",
"nodename_pattern": "- Ostris$",
"description": "Some tools to help with [a/Flex.1-alpha](https://huggingface.co/ostris/Flex.1-alpha) inference on Comfy UI."
},
{
"author": "CY-CHENYUE",
"title": "ComfyUI-Gemini-API",
"id": "ComfyUI-Gemini-API",
"reference": "https://github.com/CY-CHENYUE/ComfyUI-Gemini-API",
"files": [
"https://github.com/CY-CHENYUE/ComfyUI-Gemini-API"
],
"description": "A custom node for ComfyUI to integrate Google Gemini API.",
"install_type": "git-clone"
},
{
"author": "impactframes",
"title": "IF_ParlerTTSNode",
"reference": "https://github.com/if-ai/ComfyUI-IF_AI_ParlerTTSNode",
"files": [
"https://github.com/if-ai/ComfyUI-IF_AI_ParlerTTSNode"
],
"install_type": "git-clone",
"description": "Parler TTS is a zeroshot voice synthesis with emotion and entonations, you can control the voice style via text prompt"
},
{
"author": "impactframes",
"title": "IF_Dreamtalk",
"reference": "https://github.com/if-ai/ComfyUI-IF_AI_Dreamtalk",
"files": [
"https://github.com/if-ai/ComfyUI-IF_AI_Dreamtalk"
],
"install_type": "git-clone",
"description": "Talking avatars Heads for the IF_AI tools integrates dreamtalk in ComfyUI"
},
{
"author": "thezveroboy",
"title": "ComfyUI-CSM-Nodes",
"reference": "https://github.com/thezveroboy/ComfyUI-CSM-Nodes",
"files": [
"https://github.com/thezveroboy/ComfyUI-CSM-Nodes"
],
"description": "Custom nodes for ComfyUI implementing the csm model for text-to-speech generation.",
"install_type": "git-clone"
},
{
"author": "leeguandong",
"title": "ComfyUI_DeepSeekVL2",
"reference": "https://github.com/leeguandong/ComfyUI_DeepSeekVL2",
"files": [
"https://github.com/leeguandong/ComfyUI_DeepSeekVL2"
],
"install_type": "git-clone",
"description": "ComfyUI nodes to use [a/DeepSeek-VL2](https://github.com/deepseek-ai/DeepSeek-VL2)"
},
{
"author": "leeguandong",
"title": "ComfyUI_FluxLayerDiffuse",
"reference": "https://github.com/leeguandong/ComfyUI_FluxLayerDiffuse",
"files": [
"https://github.com/leeguandong/ComfyUI_FluxLayerDiffuse"
],
"install_type": "git-clone",
"description": "ComfyUI nodes to use [a/Flux-version-LayerDiffuse](https://github.com/RedAIGC/Flux-version-LayerDiffuse)"
},
{
"author": "leeguandong",
"title": "ComfyUI_Gemma3",
"reference": "https://github.com/leeguandong/ComfyUI_Gemma3",
"files": [
"https://github.com/leeguandong/ComfyUI_Gemma3"
],
"install_type": "git-clone",
"description": "ComfyUI nodes to use [a/gemma-3-27b-it](https://huggingface.co/google/gemma-3-27b-it)"
},
{
"author": "chri002",
"title": "ComfyUI_depthMapOperation",
"reference": "https://github.com/chri002/ComfyUI_depthMapOperation",
"files": [
"https://github.com/chri002/ComfyUI_depthMapOperation"
],
"description": "A simple set of nodes to generate a point cloud from an image and its depth map, perform transformations and some basic operations.",
"install_type": "git-clone"
},
{
"author": "pixelworldai",
"title": "ComfyUI-AlphaFlatten",
"reference": "https://github.com/pixelworldai/ComfyUI-AlphaFlatten",
"files": [
"https://github.com/pixelworldai/ComfyUI-AlphaFlatten"
],
"description": "This node takes a batch of images with alpha channels (RGBA format) and combines them into a single image, respecting the transparency of each layer. It's particularly useful for compositing multiple masked elements (like faces) into a single image.",
"install_type": "git-clone"
},
{
"author": "chenpipi0807",
"title": "ComfyUI NSFW Filter",
"reference": "https://github.com/chenpipi0807/ComfyUI_NSFW_Godie",
"files": [
"https://github.com/chenpipi0807/ComfyUI_NSFW_Godie"
],
"install_type": "git-clone",
"description": "A simple and effective ComfyUI custom node for filtering inappropriate text content, automatically detecting and replacing prohibited words while preserving the original format."
},
{
"author": "atluslin",
"title": "comfyui_arcane_style_trans",
"reference": "https://github.com/atluslin/comfyui_arcane_style_trans",
"files": [
"https://github.com/atluslin/comfyui_arcane_style_trans"
],
"description": "ComfyUI's Arcane stylization plugin",
"install_type": "git-clone"
},
{
"author": "Laurent2916",
"title": "comfyui-piq",
"reference": "https://github.com/Laurent2916/comfyui-piq",
"files": [
"https://github.com/Laurent2916/comfyui-piq"
],
"description": "PIQ ComfyUI custom nodes",
"install_type": "git-clone"
},
{
"author": "tatookan",
"title": "comfyui_ssl_gemini_EXP",
"reference": "https://github.com/tatookan/comfyui_ssl_gemini_EXP",
"files": [
"https://github.com/tatookan/comfyui_ssl_gemini_EXP"
],
"description": "Calling gemini2.0 at comfyui . The project will continue to organize good APIs!",
"install_type": "git-clone"
},
{
"author": "ali-vilab",
@@ -92,13 +424,13 @@
},
{
"author": "SSsnap",
"title": "ComfyUI-Ad_scheduler",
"title": "ComfyUI-Ad-scheduler",
"reference": "https://github.com/SS-snap/ComfyUI-Ad_scheduler",
"files": [
"https://github.com/SS-snap/ComfyUI-Ad_scheduler"
],
"install_type": "git-clone",
"description": "This node is used to enhance image details. We can add a latent space image and introduce any amount of noise. Then, we can start denoising at any timestep. This allows us to add more details to the image while maintaining overall consistency as much as possible."
"description": "For denoising tasks that handle noise at any time period, with the ability to add noise in post-processing to enhance details or correct structural accuracy while maintaining the original similarity. Allocating more steps allows the image to regress to an earlier stage.."
},
{
"author": "iDAPPA",
@@ -128,7 +460,7 @@
"https://github.com/KytraScript/ComfyUI_MatAnyone_Kytra"
],
"install_type": "git-clone",
"description": "This is a ComfyUI node for [a/MatAnyone](https://github.com/pq-yang/MatAnyone), a state-of-the-art video matting model that can remove backgrounds from videos using just a single mask for the first frame for enhanced/guided video matting."
"description": "Kytra's MatAnyone (Video Matting) implementation for ComfyUI - Based on pq-yang/MatAnyone"
},
{
"author": "irreveloper",
@@ -232,13 +564,13 @@
},
{
"author": "vadimcro",
"title": "VKriez Edge Preprocessors for ComfyUI",
"title": "VKRiez-Edge",
"reference": "https://github.com/vadimcro/VKRiez-Edge",
"files": [
"https://github.com/vadimcro/VKRiez-Edge"
],
"install_type": "git-clone",
"description": "A collection of advanced edge detection nodes for ComfyUI that generate high-quality edge maps for ControlNet guidance. Currently based on CPU computation, so might be a tid-bit on a slow side. If anyone is willing to refactor the code to GPU computation - Kudos!"
"description": "A collection of advanced edge detection nodes for ComfyUI that generate high-quality edge maps / contours for usage with ControlNet Canny / Anyline guidance."
},
{
"author": "muxueChen",
@@ -395,295 +727,6 @@
],
"install_type": "git-clone",
"description": "Quickly select preset prompts and merge them"
},
{
"author": "chenpipi0807",
"title": "PIP Artistic Words for ComfyUI",
"reference": "https://github.com/chenpipi0807/PIP_ArtisticWords",
"files": [
"https://github.com/chenpipi0807/PIP_ArtisticWords"
],
"install_type": "git-clone",
"description": "A powerful ComfyUI extension node that allows you to add various exquisite artistic text effects to your images, supporting a wide range of text styles and effects."
},
{
"author": "ifmylove2011",
"title": "comfyui-missing-tool",
"reference": "https://github.com/ifmylove2011/comfyui-missing-tool",
"files": [
"https://github.com/ifmylove2011/comfyui-missing-tool"
],
"install_type": "git-clone",
"description": "NODES: TrimBG, TrimBG Advanced, Image Queue Loader, Load Image Alpha.\nA few tools for ComfyUI, perhaps it's exactly what you need."
},
{
"author": "illuminatianon",
"title": "CSV Wildcard Node for ComfyUI",
"reference": "https://github.com/illuminatianon/comfyui-csvwildcards",
"files": [
"https://github.com/illuminatianon/comfyui-csvwildcards"
],
"install_type": "git-clone",
"description": "A ComfyUI custom node that provides dynamic text substitution using wildcards and CSV files. Perfect for creating varied prompts with consistent relationships between terms."
},
{
"author": "GeekyGhost",
"title": "ComfyUI-Geeky-Kokoro-TTS",
"reference": "https://github.com/GeekyGhost/ComfyUI-Geeky-Kokoro-TTS",
"files": [
"https://github.com/GeekyGhost/ComfyUI-Geeky-Kokoro-TTS"
],
"install_type": "git-clone",
"description": "A powerful and feature-rich custom node collection for ComfyUI that integrates the Kokoro TTS (Text-to-Speech) system with advanced voice modification capabilities. This package allows you to generate natural-sounding speech and apply various voice effects within ComfyUI workflows."
},
{
"author": "billwuhao",
"title": "ComfyUI_KokoroTTS_MW",
"reference": "https://github.com/billwuhao/ComfyUI_KokoroTTS_MW",
"files": [
"https://github.com/billwuhao/ComfyUI_KokoroTTS_MW"
],
"install_type": "git-clone",
"description": "A Text To Speech node using Kokoro TTS in ComfyUI. Supports 8 languages and 150 voices"
},
{
"author": "S4MUEL-404",
"title": "Image Position Blend",
"id": "ComfyUI-Image-Position-Blend",
"version": "1.1",
"reference": "https://github.com/S4MUEL-404/ComfyUI-Image-Position-Blend",
"files": [
"https://github.com/S4MUEL-404/ComfyUI-Image-Position-Blend"
],
"install_type": "git-clone",
"description": "A custom node for conveniently adjusting the overlay position of two images."
},
{
"author": "ZYK-AI",
"title": "ComfyUI-YK Line loading",
"id": "ComfyUI-YK_Line loading",
"reference": "https://github.com/sittere/ComfyUI-YK_Line-loading",
"files": [
"https://github.com/sittere/ComfyUI-YK_Line-loading"
],
"install_type": "git-clone",
"description": "Plugin that implements world automatic typesetting and outputs only one paragraph of text"
},
{
"author": "pxl-pshr",
"title": "GlitchNodes",
"reference": "https://github.com/pxl-pshr/GlitchNodes",
"files": [
"https://github.com/pxl-pshr/GlitchNodes"
],
"install_type": "git-clone",
"description": "GlitchNodes is a collection of image processing nodes designed for ComfyUI that specializes in creating glitch art and retro effects."
},
{
"author": "panic-titan",
"title": "ComfyUI-Gallery",
"reference": "https://github.com/PanicTitan/ComfyUI-Gallery",
"files": [
"https://github.com/PanicTitan/ComfyUI-Gallery"
],
"install_type": "git-clone",
"description": "Real-time Output Gallery for ComfyUI with image metadata inspection."
},
{
"author": "leeguandong",
"title": "ComfyUI_Cogview4",
"reference": "https://github.com/leeguandong/ComfyUI_Cogview4",
"files": [
"https://github.com/leeguandong/ComfyUI_Cogview4"
],
"install_type": "git-clone",
"description": "The latest DIT architecture-based image generation model from Zhipu that supports Chinese text generation."
},
{
"author": "marcoc2",
"title": "ComfyUI-Cog",
"reference": "https://github.com/marcoc2/ComfyUI_CogView4-6B_diffusers",
"files": [
"https://github.com/marcoc2/ComfyUI_CogView4-6B_diffusers"
],
"install_type": "git-clone",
"description": "This is a custom node aiming to run CogView4 on diffusers while there is no official implementation on ComfyUI.\nNOTE: You will need a updated version of diffusers and I don't know if updating it my break other stuff, so I advise you to make in a new instance of ComfyUI"
},
{
"author": "1038lab",
"title": "ComfyUI-Pollinations",
"reference": "https://github.com/1038lab/ComfyUI-Pollinations",
"files": [
"https://github.com/1038lab/ComfyUI-Pollinations"
],
"install_type": "git-clone",
"description": "ComfyUI integration for Pollinations API - Generate images and text based on user prompts"
},
{
"author": "Samulebotin",
"title": "ComfyUI-FreeVC_wrapper",
"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": "chflame163",
"title": "ComfyUI_CogView4_Wrapper",
"reference": "https://github.com/chflame163/ComfyUI_CogView4_Wrapper",
"files": [
"https://github.com/chflame163/ComfyUI_CogView4_Wrapper"
],
"install_type": "git-clone",
"description": "The unofficial implementation of CogView4 project in ComfyUI."
},
{
"author": "justin-vt",
"title": "ComfyUI-brushstrokes",
"reference": "https://github.com/justin-vt/ComfyUI-brushstrokes",
"files": [
"https://github.com/justin-vt/ComfyUI-brushstrokes"
],
"install_type": "git-clone",
"description": "A ComfyUI node that applies painterly/brush-stroke effects to images, using either ImageMagick (Wand) or G'MIC (gmic-py) under the hood."
},
{
"author": "huixingyun",
"title": "ComfyUI-HX-Pimg",
"reference": "https://github.com/huixingyun/ComfyUI-HX-Pimg",
"files": [
"https://github.com/huixingyun/ComfyUI-HX-Pimg"
],
"install_type": "git-clone",
"description": "Some custom nodes used for pimg (a comfyui controller deployed in huixingyun)."
},
{
"author": "bombax-xiaoice",
"title": "ComfyUI-DisPose",
"reference": "https://github.com/bombax-xiaoice/ComfyUI-DisPose",
"files": [
"https://github.com/bombax-xiaoice/ComfyUI-DisPose"
],
"install_type": "git-clone",
"description": "ComfyUI supports over lihxxx/DisPose, which generates a new video with a reference video as poses and a reference image as everything else."
},
{
"author": "TheWhykiki",
"title": "Whykiki ComfyUI Toolset",
"reference": "https://github.com/TheWhykiki/Whykiki-ComfyUIToolset",
"files": [
"https://github.com/TheWhykiki/Whykiki-ComfyUIToolset"
],
"install_type": "git-clone",
"description": "A collection of useful nodes for ComfyUI that provide various workflow enhancements."
},
{
"author": "nosiu",
"title": "comfyui-text-randomizer",
"id": "comfyui-text-randomizer",
"reference": "https://github.com/nosiu/comfyui-text-randomizer",
"files": [
"https://github.com/nosiu/comfyui-text-randomizer"
],
"install_type": "git-clone",
"description": "A simple text randomizer for ComfyUI that can generate random and surprising results"
},
{
"author": "mr7thing",
"title": "Circle Pattern Processor for ComfyUI",
"reference": "https://github.com/mr7thing/circle_pattern_processor",
"files": [
"https://github.com/mr7thing/circle_pattern_processor"
],
"install_type": "git-clone",
"description": "This is a custom node for ComfyUI that can detect circular patterns in an image and generate a standardized circular output."
},
{
"author": "keit",
"title": "ComfyUI-Image-Toolkit",
"id": "comfyui-image-toolkit",
"reference": "https://github.com/keit0728/ComfyUI-Image-Toolkit",
"files": [
"https://github.com/keit0728/ComfyUI-Image-Toolkit"
],
"install_type": "git-clone",
"description": "ComfyUI nodes for image processing."
},
{
"author": "Mango1010",
"title": "Mango Node Pack",
"id": "MangoNodePack",
"reference": "https://github.com/mang01010/MangoNodePack",
"files": [
"https://github.com/mang01010/MangoNodePack"
],
"install_type": "git-clone",
"description": "Node pack designed to save images with metadata supported by Civitai."
},
{
"author": "0xRavenBlack",
"title": "ComfyUI-OOP",
"reference": "https://github.com/0xRavenBlack/ComfyUI-OOP",
"files": [
"https://github.com/0xRavenBlack/ComfyUI-OOP"
],
"install_type": "git-clone",
"description": "ComfyUI Node to create Object-Oriented Prompts"
},
{
"author": "Legorobotdude",
"title": "ComfyUI-VariationLab",
"reference": "https://github.com/Legorobotdude/ComfyUI-VariationLab",
"files": [
"https://github.com/Legorobotdude/ComfyUI-VariationLab"
],
"install_type": "git-clone",
"description": "Helps explore different parameters quickly"
},
{
"author": "lthero",
"title": "ComfyUI-GaussianShadingWatermark",
"reference": "https://github.com/lthero-big/ComfyUI-GaussianShadingWatermark",
"files": [
"https://github.com/lthero-big/ComfyUI-GaussianShadingWatermark"
],
"install_type": "git-clone",
"description": "Add invisible watermark to images to protect your images"
},
{
"author": "ajbergh",
"title": "ComfyUI Intelligent Detail Detector",
"reference": "https://github.com/ajbergh/comfyui-IntelligentDetailDetector",
"files": [
"https://github.com/ajbergh/comfyui-IntelligentDetailDetector"
],
"install_type": "git-clone",
"description": "A custom node for ComfyUI that intelligently analyzes images to detect areas that would benefit from detail enhancement, outputting a weighted mask highlighting regions needing enhancement.A custom node for ComfyUI that intelligently analyzes images to detect areas that would benefit from detail enhancement, outputting a weighted mask highlighting regions needing enhancement."
},
{
"author": "kijai",
"title": "ComfyUI-HFRemoteVae",
"reference": "https://github.com/kijai/ComfyUI-HFRemoteVae",
"files": [
"https://github.com/kijai/ComfyUI-HFRemoteVae"
],
"install_type": "git-clone",
"description": "This node allows using Hugginface remote server for latent decoding. Currently supported models: SD, SDXL, Flux, HunyuanVideo"
},
{
"author": "JohanK66",
"title": "ComfyUI WebhookImage",
"reference": "https://github.com/JohanK66/ComfyUI-WebhookImage",
"files": [
"https://github.com/JohanK66/ComfyUI-WebhookImage"
],
"install_type": "git-clone",
"description": "This package provides a custom node to ComfyUI to send a message and image by means of a webhook"
}
]
}

View File

File diff suppressed because it is too large Load Diff

View File

@@ -311,6 +311,16 @@
],
"description": "ComfyUI node for creating some Turtle Graphic demos.",
"install_type": "git-clone"
},
{
"author": "cozy-comfyui",
"title": "cozy_ex_dynamic",
"reference": "https://github.com/cozy-comfyui/cozy_ex_dynamic",
"files": [
"https://github.com/cozy-comfyui/cozy_ex_dynamic"
],
"description": "Dynamic Node examples for ComfyUI",
"install_type": "git-clone"
}
]
}

View File

@@ -23,15 +23,18 @@ import folder_paths
manager_util.add_python_path_to_env()
import datetime
if hasattr(datetime, 'datetime'):
from datetime import datetime
import datetime as dt
if hasattr(dt, 'datetime'):
from datetime import datetime as dt_datetime
def current_timestamp():
return datetime.now().strftime('%Y-%m-%d %H:%M:%S.%f')[:-3]
return dt_datetime.now().strftime('%Y-%m-%d %H:%M:%S.%f')[:-3]
else:
# NOTE: Occurs in some Mac environments.
import time
logging.error(f"[ComfyUI-Manager] fallback timestamp mode\n datetime module is invalid: '{datetime.__file__}'")
logging.error(f"[ComfyUI-Manager] fallback timestamp mode\n datetime module is invalid: '{dt.__file__}'")
def current_timestamp():
return str(time.time()).split('.')[0]
@@ -689,14 +692,6 @@ def execute_lazy_cnr_switch(target, zip_url, from_path, to_path, no_deps, custom
file.write('\n'.join(list(extracted)))
def execute_migration(moves):
import shutil
for x in moves:
if os.path.exists(x[0]) and not os.path.exists(x[1]):
shutil.move(x[0], x[1])
print(f"[ComfyUI-Manager] MIGRATION: '{x[0]}' -> '{x[1]}'")
script_executed = False
def execute_startup_script():
@@ -754,9 +749,6 @@ def execute_startup_script():
execute_lazy_cnr_switch(script[0], script[2], script[3], script[4], script[5], script[6])
execute_lazy_install_script(script[3], script[7])
elif script[1] == "#LAZY-MIGRATION":
execute_migration(script[2])
elif script[1] == "#LAZY-DELETE-NODEPACK":
execute_lazy_delete(script[2])

View File

@@ -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.31.1"
version = "3.31.6"
license = { file = "LICENSE.txt" }
dependencies = ["GitPython", "PyGithub", "matrix-client==0.4.0", "transformers", "huggingface-hub>0.20", "typer", "rich", "typing-extensions", "toml", "uv", "chardet"]