Compare commits
24 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
4fd17b0bf5 | ||
|
|
76d2206058 | ||
|
|
51e8b608dc | ||
|
|
a68330fb8f | ||
|
|
2449ad5c69 | ||
|
|
064c812df3 | ||
|
|
48d5ec9e66 | ||
|
|
914419fd1e | ||
|
|
f005fc8ca0 | ||
|
|
43b7960de2 | ||
|
|
2ed1e58032 | ||
|
|
c63b212700 | ||
|
|
e9df78c0e7 | ||
|
|
b0daf81185 | ||
|
|
cee4fdcbb0 | ||
|
|
df3cdfccb0 | ||
|
|
894042cd0e | ||
|
|
8123287952 | ||
|
|
bc677705d8 | ||
|
|
5dd8ea8aab | ||
|
|
41172be796 | ||
|
|
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`
|
* Basic config files: `<USER_DIRECTORY>/default/ComfyUI-Manager/config.ini`
|
||||||
* Configurable channel lists: `<USER_DIRECTORY>/default/ComfyUI-Manager/channels.ini`
|
* Configurable channel lists: `<USER_DIRECTORY>/default/ComfyUI-Manager/channels.ini`
|
||||||
* Configurable pip overrides: `<USER_DIRECTORY>/default/ComfyUI-Manager/pip_overrides.json`
|
* Configurable pip overrides: `<USER_DIRECTORY>/default/ComfyUI-Manager/pip_overrides.json`
|
||||||
* Configurable pip blacklist: `<USER_DIRECTORY>/default/ComfyUI-Manager/pip_overrides.list`
|
* Configurable pip blacklist: `<USER_DIRECTORY>/default/ComfyUI-Manager/pip_blacklist.list`
|
||||||
* Saved snapshot files: `<USER_DIRECTORY>/default/ComfyUI-Manager/snapshots`
|
* Saved snapshot files: `<USER_DIRECTORY>/default/ComfyUI-Manager/snapshots`
|
||||||
* Startup script files: `<USER_DIRECTORY>/default/ComfyUI-Manager/startup-scripts`
|
* Startup script files: `<USER_DIRECTORY>/default/ComfyUI-Manager/startup-scripts`
|
||||||
* Component files: `<USER_DIRECTORY>/default/ComfyUI-Manager/components`
|
* Component files: `<USER_DIRECTORY>/default/ComfyUI-Manager/components`
|
||||||
@@ -313,6 +313,29 @@ The following settings are applied based on the section marked as `is_default`.
|
|||||||
* This option can be used if performance issues occur in a Colab+GDrive environment.
|
* This option can be used if performance issues occur in a Colab+GDrive environment.
|
||||||
|
|
||||||
|
|
||||||
|
## Environment Variables
|
||||||
|
|
||||||
|
The following features can be configured using environment variables:
|
||||||
|
|
||||||
|
* **COMFYUI_PATH**: The installation path of ComfyUI
|
||||||
|
* **GITHUB_ENDPOINT**: Reverse proxy configuration for environments with limited access to GitHub
|
||||||
|
* **HF_ENDPOINT**: Reverse proxy configuration for environments with limited access to Hugging Face
|
||||||
|
|
||||||
|
|
||||||
|
### Example 1:
|
||||||
|
Redirecting `https://github.com/ltdrdata/ComfyUI-Impact-Pack` to `https://mirror.ghproxy.com/https://github.com/ltdrdata/ComfyUI-Impact-Pack`
|
||||||
|
|
||||||
|
```
|
||||||
|
GITHUB_ENDPOINT=https://mirror.ghproxy.com/https://github.com
|
||||||
|
```
|
||||||
|
|
||||||
|
#### Example 2:
|
||||||
|
Changing `https://huggingface.co/path/to/somewhere` to `https://some-hf-mirror.com/path/to/somewhere`
|
||||||
|
|
||||||
|
```
|
||||||
|
HF_ENDPOINT=https://some-hf-mirror.com
|
||||||
|
```
|
||||||
|
|
||||||
## Scanner
|
## Scanner
|
||||||
When you run the `scan.sh` script:
|
When you run the `scan.sh` script:
|
||||||
|
|
||||||
|
|||||||
@@ -76,7 +76,7 @@ core.check_invalid_nodes()
|
|||||||
def read_downgrade_blacklist():
|
def read_downgrade_blacklist():
|
||||||
try:
|
try:
|
||||||
import configparser
|
import configparser
|
||||||
config = configparser.ConfigParser()
|
config = configparser.ConfigParser(strict=False)
|
||||||
config.read(core.manager_config.path)
|
config.read(core.manager_config.path)
|
||||||
default_conf = config['default']
|
default_conf = config['default']
|
||||||
|
|
||||||
|
|||||||
@@ -5443,7 +5443,7 @@
|
|||||||
"https://github.com/lldacing/ComfyUI_Patches_ll"
|
"https://github.com/lldacing/ComfyUI_Patches_ll"
|
||||||
],
|
],
|
||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "Some patches for Flux|HunYuanVideo etc, support TeaCache, PuLID."
|
"description": "Some patches for Flux|HunYuanVideo|LTXVideo etc, support TeaCache, PuLID, First Block Cache."
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"author": "lldacing",
|
"author": "lldacing",
|
||||||
@@ -6433,6 +6433,16 @@
|
|||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "Make it possible to edit the prompt using the Monaco Editor, an editor implementation used in VSCode.\nNOTE: This extension supports both ComfyUI and A1111 simultaneously."
|
"description": "Make it possible to edit the prompt using the Monaco Editor, an editor implementation used in VSCode.\nNOTE: This extension supports both ComfyUI and A1111 simultaneously."
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"author": "Taremin",
|
||||||
|
"title": "comfyui-keep-multiple-tabs",
|
||||||
|
"reference": "https://github.com/Taremin/comfyui-keep-multiple-tabs",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/Taremin/comfyui-keep-multiple-tabs"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "This is an extension for ComfyUI. It retains multiple workflow tabs so that they are not lost when reloading or restarting."
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"author": "foxtrot-roger",
|
"author": "foxtrot-roger",
|
||||||
"title": "RF Nodes",
|
"title": "RF Nodes",
|
||||||
@@ -10068,6 +10078,16 @@
|
|||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "a custom node for [a/echomimic_v2](https://github.com/antgroup/echomimic_v2)"
|
"description": "a custom node for [a/echomimic_v2](https://github.com/antgroup/echomimic_v2)"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"author": "AIFSH",
|
||||||
|
"title": "SemiChat-ComfyUI",
|
||||||
|
"reference": "https://github.com/AIFSH/SemiChat-ComfyUI",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/AIFSH/SemiChat-ComfyUI"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A ComfyUI chat node based on SemiUI."
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"author": "Koishi-Star",
|
"author": "Koishi-Star",
|
||||||
"title": "Euler-Smea-Dyn-Sampler",
|
"title": "Euler-Smea-Dyn-Sampler",
|
||||||
@@ -10473,6 +10493,26 @@
|
|||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "[a/CSD_MT](https://github.com/Snowfallingplum/CSD-MT) is a method about 'Content-Style Decoupling for Unsupervised Makeup Transfer without Generating Pseudo Ground Truth', you can use it in comfyUI."
|
"description": "[a/CSD_MT](https://github.com/Snowfallingplum/CSD-MT) is a method about 'Content-Style Decoupling for Unsupervised Makeup Transfer without Generating Pseudo Ground Truth', you can use it in comfyUI."
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"author": "smthemex",
|
||||||
|
"title": "ComfyUI_Light_A_Video",
|
||||||
|
"reference": "https://github.com/smthemex/ComfyUI_Light_A_Video",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/smthemex/ComfyUI_Light_A_Video"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Light-A-Video: Training-free Video Relighting via Progressive Light Fusion,you can use it in comfyUI"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "smthemex",
|
||||||
|
"title": "ComfyUI_YuE",
|
||||||
|
"reference": "https://github.com/smthemex/ComfyUI_YuE",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/smthemex/ComfyUI_YuE"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "[a/YuE](https://github.com/multimodal-art-projection/YuE) is a groundbreaking series of open-source foundation models designed for music generation, specifically for transforming lyrics into full songs (lyrics2song). you can use it in comfyUI"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"author": "choey",
|
"author": "choey",
|
||||||
"title": "Comfy-Topaz",
|
"title": "Comfy-Topaz",
|
||||||
@@ -10633,6 +10673,16 @@
|
|||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "A ComfyUI extension for Riffusion audio generation."
|
"description": "A ComfyUI extension for Riffusion audio generation."
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"author": "quadmoon",
|
||||||
|
"title": "ComfyUI-UltimateSDUpscale-GGUF",
|
||||||
|
"reference": "https://github.com/traugdor/ComfyUI-UltimateSDUpscale-GGUF",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/traugdor/ComfyUI-UltimateSDUpscale-GGUF"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "GGUF implementation for the ComfyUI Ultimate SD Upscale node."
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"author": "quadme7macoon",
|
"author": "quadme7macoon",
|
||||||
"title": "ComfyUI-ShadertoyGL",
|
"title": "ComfyUI-ShadertoyGL",
|
||||||
@@ -11259,6 +11309,17 @@
|
|||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "This extension contains a custom node for ComfyUI. The node, called 'Bounding Box Crop', is designed to compute the top-left coordinates of a cropped bounding box based on input coordinates and dimensions of the final cropped image. It does so computing the center of the cropping area and then computing where the top-left coordinates would be."
|
"description": "This extension contains a custom node for ComfyUI. The node, called 'Bounding Box Crop', is designed to compute the top-left coordinates of a cropped bounding box based on input coordinates and dimensions of the final cropped image. It does so computing the center of the cropping area and then computing where the top-left coordinates would be."
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"author": "alessandrozonta",
|
||||||
|
"title": "Comfyui-LoopLoader",
|
||||||
|
"id": "Comfyui-LoopLoader",
|
||||||
|
"reference": "https://github.com/alessandrozonta/Comfyui-LoopLoader",
|
||||||
|
"files": [
|
||||||
|
"hhttps://github.com/alessandrozonta/Comfyui-LoopLoader"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A ComfyUI custom node for loading images sequentially from a directory. Loops back to the first image when reaching the end"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"author": "curiousjp",
|
"author": "curiousjp",
|
||||||
"title": "ComfyUI-MaskBatchPermutations",
|
"title": "ComfyUI-MaskBatchPermutations",
|
||||||
@@ -12979,7 +13040,7 @@
|
|||||||
"https://github.com/licyk/ComfyUI-Restart-Sampler"
|
"https://github.com/licyk/ComfyUI-Restart-Sampler"
|
||||||
],
|
],
|
||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "This extension is a node that directly expands the functionality of KSampler, adding the TCD sampling to KSampler."
|
"description": "This extension is a node that directly expands the functionality of KSampler, rather than being in the form of a custom node. [w/Workflows created using this feature are not compatible with other users.]"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"author": "licyk",
|
"author": "licyk",
|
||||||
@@ -14757,6 +14818,16 @@
|
|||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "A flexible and customizable prompt generator for generating detailed and creative prompts for image generation models for ComfyUI"
|
"description": "A flexible and customizable prompt generator for generating detailed and creative prompts for image generation models for ComfyUI"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"author": "fairy-root",
|
||||||
|
"title": "ComfyUI-Show-Text",
|
||||||
|
"reference": "https://github.com/fairy-root/ComfyUI-Show-Text",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/fairy-root/ComfyUI-Show-Text"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A simple but powerful node for ComfyUI that displays text input in a readable format. Perfect for viewing outputs from text generation nodes, prompt builders, interrogators, and more."
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"author": "ryanontheinside",
|
"author": "ryanontheinside",
|
||||||
"title": "RyanOnTheInside",
|
"title": "RyanOnTheInside",
|
||||||
@@ -15274,6 +15345,16 @@
|
|||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "Simple Node to make panoramic images"
|
"description": "Simple Node to make panoramic images"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"author": "RodrigoSKohl",
|
||||||
|
"title": "Interior Design for Comfyui",
|
||||||
|
"reference": "https://github.com/RodrigoSKohl/InteriorDesign-for-ComfyUI",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/RodrigoSKohl/InteriorDesign-for-ComfyUI"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "This node is based on MykolaL/StableDesign"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"author": "RodrigoSKohl",
|
"author": "RodrigoSKohl",
|
||||||
"title": "TryOff Anyone",
|
"title": "TryOff Anyone",
|
||||||
@@ -15471,6 +15552,17 @@
|
|||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "This is a custom node to convert only the Diffusion model part or CLIP model part to fp8 in ComfyUI.\nVAE fp8 conversion is not supported.\nThe advantage of this node is that you do not need to separate unet/clip/vae in advance when converting to fp8, but can use the safetenros files that ComfyUI provides."
|
"description": "This is a custom node to convert only the Diffusion model part or CLIP model part to fp8 in ComfyUI.\nVAE fp8 conversion is not supported.\nThe advantage of this node is that you do not need to separate unet/clip/vae in advance when converting to fp8, but can use the safetenros files that ComfyUI provides."
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"author": "Shiba-2-shiba",
|
||||||
|
"title": "ComfyUI_FreeU_V2_timestepadd",
|
||||||
|
"id": "ComfyUI_FreeU_V2_timestepadd",
|
||||||
|
"reference": "https://github.com/Shiba-2-shiba/ComfyUI_FreeU_V2_timestepadd",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/Shiba-2-shiba/ComfyUI_FreeU_V2_timestepadd"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "This is a custom node to add timestep for FreeU V2."
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"author": "Bao Pham",
|
"author": "Bao Pham",
|
||||||
"title": "ComfyUI-LyraVSIH",
|
"title": "ComfyUI-LyraVSIH",
|
||||||
@@ -16536,7 +16628,7 @@
|
|||||||
"description": "This repository contains a custom ComfyUI node for overlaying media using ffmpeg."
|
"description": "This repository contains a custom ComfyUI node for overlaying media using ffmpeg."
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"author": "laogou666",
|
"author": "LAOGOU-666",
|
||||||
"title": "ComfyUI_LG_FFT",
|
"title": "ComfyUI_LG_FFT",
|
||||||
"reference": "https://github.com/LAOGOU-666/ComfyUI_LG_FFT",
|
"reference": "https://github.com/LAOGOU-666/ComfyUI_LG_FFT",
|
||||||
"files": [
|
"files": [
|
||||||
@@ -16546,7 +16638,7 @@
|
|||||||
"description": "Implementation of Fast Fourier Transform in COMFYUI"
|
"description": "Implementation of Fast Fourier Transform in COMFYUI"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"author": "laogou666",
|
"author": "LAOGOU-666",
|
||||||
"title": "Comfyui-LG_Relight",
|
"title": "Comfyui-LG_Relight",
|
||||||
"reference": "https://github.com/LAOGOU-666/Comfyui-LG_Relight",
|
"reference": "https://github.com/LAOGOU-666/Comfyui-LG_Relight",
|
||||||
"files": [
|
"files": [
|
||||||
@@ -16555,6 +16647,17 @@
|
|||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "A simple implementation of real-time 3D lighting in ComfyUI. It's an open-source node, have fun playing around!"
|
"description": "A simple implementation of real-time 3D lighting in ComfyUI. It's an open-source node, have fun playing around!"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"author": "LAOGOU-666",
|
||||||
|
"title": "ComfyUI-LG_HotReload",
|
||||||
|
"id": "ComfyUI-LG_HotReload",
|
||||||
|
"reference": "https://github.com/LAOGOU-666/Comfyui-LG_HotReload",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/LAOGOU-666/Comfyui-LG_HotReload"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "An extension for ComfyUI that allows hot reloading. Once installed, you can preview changes in real-time while developing custom nodes or installing plugins without restarting ComfyUI."
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"author": "VertexStudio",
|
"author": "VertexStudio",
|
||||||
"title": "roblox-comfyui-nodes",
|
"title": "roblox-comfyui-nodes",
|
||||||
@@ -17132,7 +17235,7 @@
|
|||||||
"https://github.com/mfg637/ComfyUI-ScheduledGuider-Ext"
|
"https://github.com/mfg637/ComfyUI-ScheduledGuider-Ext"
|
||||||
],
|
],
|
||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "NODES:ScheduledCFGGuider, PerpNegScheduledCFGGuider, CosineScheduler, Add zSNR Sigma max, InvertSigmas, ConcatSigmas, OffsetSigmas"
|
"description": "This extension contains various nodes for CFG scheduling and more. NODES:ScheduledCFGGuider, PerpNegScheduledCFGGuider, CosineScheduler, GaussianScheduler, LogNormalScheduler, InvertSigmas, ConcatSigmas, OffsetSigmas, SplitSigmasByValue"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"author": "changwook987",
|
"author": "changwook987",
|
||||||
@@ -18921,6 +19024,16 @@
|
|||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "A beautiful theme extension for ComfyUI that adds festive touches with dynamic backgrounds, snowfall effects, and animated node connections"
|
"description": "A beautiful theme extension for ComfyUI that adds festive touches with dynamic backgrounds, snowfall effects, and animated node connections"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"author": "AEmotionStudio",
|
||||||
|
"title": "ComfyUI-EnhancedLinksandNodes 🎨✨",
|
||||||
|
"reference": "https://github.com/AEmotionStudio/ComfyUI-EnhancedLinksandNodes",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/AEmotionStudio/ComfyUI-EnhancedLinksandNodes"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A visually stunning extension for ComfyUI that adds beautiful, customizable animations to both links and nodes in your workflow, with a focus on performance and customization. Includes an end-of-render animation and a text visibility tool for nodes. No extra packages are required, works with the latest version of ComfyUI, and should be compatible with most workflows. Larger workflows may experience performance issues, especially if you have a lot of nodes and are using a lower end system."
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"author": "xfgexo",
|
"author": "xfgexo",
|
||||||
"title": "EXO Custom ComfyUI Nodes",
|
"title": "EXO Custom ComfyUI Nodes",
|
||||||
@@ -18972,6 +19085,16 @@
|
|||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "A ComfyUI node that detects the skin tone of a person in an image and matches it to the standard emoji skin tone palette."
|
"description": "A ComfyUI node that detects the skin tone of a person in an image and matches it to the standard emoji skin tone palette."
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"author": "kevinmcmahondev",
|
||||||
|
"title": "KMCDev Nodes",
|
||||||
|
"reference": "https://github.com/kevinmcmahondev/comfyui-kmcdev-image-filter-adjustments",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/kevinmcmahondev/comfyui-kmcdev-image-filter-adjustments"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A ComfyUI node that provides advanced image adjustment filters and controls for image manipulation"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"author": "mahdi",
|
"author": "mahdi",
|
||||||
"title": "seamless-clone-comfyui",
|
"title": "seamless-clone-comfyui",
|
||||||
@@ -19423,6 +19546,16 @@
|
|||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "ComfyUI_OneButtonPrompt_Flux is a Flux prompt generation node. The subject can be 'human,' 'other' or a combination of both. For human, pose settings can be enabled. Additionally, various styles can be applied. Finally, combine it with 'Prompt Enhancement' to seamlessly automate image generation, eliminating the hassle of designing prompts."
|
"description": "ComfyUI_OneButtonPrompt_Flux is a Flux prompt generation node. The subject can be 'human,' 'other' or a combination of both. For human, pose settings can be enabled. Additionally, various styles can be applied. Finally, combine it with 'Prompt Enhancement' to seamlessly automate image generation, eliminating the hassle of designing prompts."
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"author": "billwuhao",
|
||||||
|
"title": "ComfyUI_StepAudioTTS",
|
||||||
|
"reference": "https://github.com/billwuhao/ComfyUI_StepAudioTTS",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/billwuhao/ComfyUI_StepAudioTTS"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A Text To Speech node using Step-Audio-TTS in ComfyUI. Can speak, rap, sing, or clone voice."
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"author": "pandaer119",
|
"author": "pandaer119",
|
||||||
"title": "ComfyUI_pandai",
|
"title": "ComfyUI_pandai",
|
||||||
@@ -19576,6 +19709,16 @@
|
|||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "NODES: ComfyUI-ImageFx, ComfyUI-Whisk"
|
"description": "NODES: ComfyUI-ImageFx, ComfyUI-Whisk"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"author": "ainewsto",
|
||||||
|
"title": "Comfyui_Comfly",
|
||||||
|
"reference": "https://github.com/ainewsto/Comfyui_Comfly",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/ainewsto/Comfyui_Comfly"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "NODES: Comfly_Mj, Comfly_mjstyle, Comfly_upload, Comfly_Mju, Comfly_Mjv, Comfly_kling_videoPreview"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"author": "gremlation",
|
"author": "gremlation",
|
||||||
"title": "ComfyUI-ViewData",
|
"title": "ComfyUI-ViewData",
|
||||||
@@ -20615,6 +20758,16 @@
|
|||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "This plugin integrates the Janus-Pro multi-modal model into ComfyUI, enabling advanced image understanding and text-to-image generation capabilities. It supports both image analysis and creative image generation workflows."
|
"description": "This plugin integrates the Janus-Pro multi-modal model into ComfyUI, enabling advanced image understanding and text-to-image generation capabilities. It supports both image analysis and creative image generation workflows."
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"author": "greengerong",
|
||||||
|
"title": "ComfyUI-Lumina-Video",
|
||||||
|
"reference": "https://github.com/greengerong/ComfyUI-Lumina-Video",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/greengerong/ComfyUI-Lumina-Video"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "This is a video generation plugin implementation for ComfyUI based on the Lumina Video model."
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"author": "raindrop313",
|
"author": "raindrop313",
|
||||||
"title": "ComfyUI_SD3_Flowedit",
|
"title": "ComfyUI_SD3_Flowedit",
|
||||||
@@ -20841,14 +20994,14 @@
|
|||||||
"description": "Additional ComfyUI nodes to utilise the Transformers pipeline in a simple and modular way."
|
"description": "Additional ComfyUI nodes to utilise the Transformers pipeline in a simple and modular way."
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"author": "iris-Neko",
|
"author": "IrisRainbowNeko",
|
||||||
"title": "ComfyUI_ascii_art",
|
"title": "ascii-art-comfyui",
|
||||||
"reference": "https://github.com/iris-Neko/ComfyUI_ascii_art",
|
"reference": "https://github.com/Deep-Neko/ComfyUI_ascii_art",
|
||||||
"files": [
|
"files": [
|
||||||
"https://github.com/iris-Neko/ComfyUI_ascii_art"
|
"https://github.com/Deep-Neko/ComfyUI_ascii_art"
|
||||||
],
|
],
|
||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "ComfyUI node for [a/ASCII art controlnet](https://civitai.com/models/986392)"
|
"description": "ascii art preprocessors in ComfyUI"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"author": "mie",
|
"author": "mie",
|
||||||
@@ -20911,6 +21064,16 @@
|
|||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "This node calculates a contrasting complementary color based on an input RGB color. The goal is to ensure visibility and contrast when overlaying text, UI elements, or graphical components against a given background color."
|
"description": "This node calculates a contrasting complementary color based on an input RGB color. The goal is to ensure visibility and contrast when overlaying text, UI elements, or graphical components against a given background color."
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"author": "dasilva333",
|
||||||
|
"title": "ComfyUI_MarkdownImage",
|
||||||
|
"reference": "https://github.com/dasilva333/ComfyUI_MarkdownImage",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/dasilva333/ComfyUI_MarkdownImage"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "This project generates an image from Markdown text using imgkit and wkhtmltoimage. It automatically scales the text to fit within the specified image dimensions."
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"author": "moon7star9",
|
"author": "moon7star9",
|
||||||
"title": "ComfyUI_BiRefNet_Universal",
|
"title": "ComfyUI_BiRefNet_Universal",
|
||||||
@@ -20932,26 +21095,16 @@
|
|||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "This node is a node made by GMapeSplat/ComfyUI_ezXY that i copied while his node doesn't work"
|
"description": "This node is a node made by GMapeSplat/ComfyUI_ezXY that i copied while his node doesn't work"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"author": "thanhduong0213929",
|
|
||||||
"title": "ComfyUI-DeepUnlock",
|
|
||||||
"reference": "https://github.com/thanhduong0213929/ComfyUI-DeepUnlock",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/thanhduong0213929/ComfyUI-DeepUnlock"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "DeepFuze is a state-of-the-art deep learning tool that seamlessly integrates with ComfyUI to revolutionize facial transformations, lipsyncing, video generation, voice cloning, face swapping, and lipsync translation. Leveraging advanced algorithms, DeepFuze enables users to combine audio and video with unparalleled realism, ensuring perfectly synchronized facial movements. This innovative solution is ideal for content creators, animators, developers, and anyone seeking to elevate their video editing projects with sophisticated AI-driven features."
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"author": "TheAIDoctor",
|
"author": "TheAIDoctor",
|
||||||
"title": "The AI Doctors Clinical Tools",
|
"title": "The AI Doctors Clinical Tools",
|
||||||
"id": "AIDocCT",
|
"id": "The-AI-Doctors-Clinical-Tools",
|
||||||
"reference": "https://github.com/BlueprintCoding/ComfyUI_AIDocsClinicalTools",
|
"reference": "https://github.com/BlueprintCoding/ComfyUI_AIDocsClinicalTools",
|
||||||
"files": [
|
"files": [
|
||||||
"https://github.com/BlueprintCoding/ComfyUI_AIDocsClinicalTools"
|
"https://github.com/BlueprintCoding/ComfyUI_AIDocsClinicalTools"
|
||||||
],
|
],
|
||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "MultiInt and MultiText nodes. The MultiInt node allows management of multiple int values with configurable steps, +/- buttons, drag change, & customized labels. The MultiText node offers similar functionality for string values."
|
"description": "Nodes: Multi Int and Multi Text; allows for the creation of multiple int and multiple string storage and output from a single node. Multi Float coming soon."
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"author": "Mohammadreza Mohseni",
|
"author": "Mohammadreza Mohseni",
|
||||||
@@ -21014,6 +21167,230 @@
|
|||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "This repository explains how to accelerate image generation in ComfyUI using Pruna, an inference optimization engine that makes AI models faster, smaller, cheaper, and greener. ComfyUI is a popular node-based GUI for image generation models, for which we provide a custom compilation node that accelerates Stable Diffusion (SD) and Flux inference, while preserving output quality."
|
"description": "This repository explains how to accelerate image generation in ComfyUI using Pruna, an inference optimization engine that makes AI models faster, smaller, cheaper, and greener. ComfyUI is a popular node-based GUI for image generation models, for which we provide a custom compilation node that accelerates Stable Diffusion (SD) and Flux inference, while preserving output quality."
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"author": "Hellfiredragon",
|
||||||
|
"title": "comfyui-image-manipulation",
|
||||||
|
"reference": "https://github.com/Hellfiredragon/comfyui-image-manipulation",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/Hellfiredragon/comfyui-image-manipulation"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Custom nodes to manipulate images in ComfyUI"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "lunarring",
|
||||||
|
"title": "bitalino_comfy",
|
||||||
|
"reference": "https://github.com/lunarring/bitalino_comfy",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/lunarring/bitalino_comfy"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A package implementing a Bitalino device ComfyUI custom node."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "AIDC-AI",
|
||||||
|
"title": "ComfyUI-Copilot",
|
||||||
|
"id": "ComfyUI-Copilot",
|
||||||
|
"reference": "https://github.com/AIDC-AI/ComfyUI-Copilot",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/AIDC-AI/ComfyUI-Copilot"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Your Intelligent Assistant for Comfy-UI."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "attashe",
|
||||||
|
"title": "ComfyUI-FluxRegionAttention",
|
||||||
|
"reference": "https://github.com/attashe/ComfyUI-FluxRegionAttention",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/attashe/ComfyUI-FluxRegionAttention"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Implement Region Attention for Flux model. Add node RegionAttention that takes a regions - mask + condition, mask could be set from comfyui masks or bbox in FluxRegionBBOX node.\nThis code is not optimized and has a memory leak. If you caught a OOM just try run a query againg - works on my RTX3080. For generation it uses a usual prompt that have influence to all picture and a regions that have their own prompts.\nBase prompt good for setup background and style of image. This is train-free technique and results not always stable - sometimes need to try several seeds or change prompt."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "RodrigoSKohl",
|
||||||
|
"title": "Interior Design for Comfyui",
|
||||||
|
"reference": "https://github.com/RodrigoSKohl/StableDesign-for-ComfyUI",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/RodrigoSKohl/StableDesign-for-ComfyUI"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "This node is based on MykolaL/StableDesign"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "yas-ponotech",
|
||||||
|
"title": "ComfyUI-Stability-AI-API",
|
||||||
|
"reference": "https://github.com/yhayano-ponotech/comfyui-stability-ai-api",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/yhayano-ponotech/comfyui-stability-ai-api"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A collection of custom nodes for using the Stability AI API in ComfyUI."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "HJH-AILab",
|
||||||
|
"title": "ComfyUI_StableAnimator",
|
||||||
|
"reference": "https://github.com/HJH-AILab/ComfyUI_StableAnimator",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/HJH-AILab/ComfyUI_StableAnimator"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "ComfyUI nodes for StableAnimator"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "Easymode-ai",
|
||||||
|
"title": "ComfyUI-ShadowR",
|
||||||
|
"reference": "https://github.com/Easymode-ai/ComfyUI-ShadowR",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/Easymode-ai/ComfyUI-ShadowR"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "ComfyUI [a/movingforward100/Shadow_R](https://github.com/movingforward100/Shadow_R) Wrapper"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "GamingDaveUk",
|
||||||
|
"title": "Daves Nodes",
|
||||||
|
"id": "davesnodes",
|
||||||
|
"reference": "https://github.com/GamingDaveUk/daves_nodes",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/GamingDaveUk/daves_nodes"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Nodes that I needed but couldnt find, so ended up making."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "chenlongming",
|
||||||
|
"title": "ComfyUI_Spectral",
|
||||||
|
"reference": "https://github.com/chenlongming/ComfyUI_Spectral",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/chenlongming/ComfyUI_Spectral"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "ComfyUI Spectral is a ComfyUI custom nodes library based on the spectral, mainly used for visual processing of spectral files"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "Chengym2023",
|
||||||
|
"title": "ComfyUI-DeepSeek_Online",
|
||||||
|
"reference": "https://github.com/Chengym2023/ComfyUI-DeepSeek_Online",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/Chengym2023/ComfyUI-DeepSeek_Online"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "NODES: SiliconCloudReasoning, DeepSeekOnline"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "gitmylo",
|
||||||
|
"title": "Audio nodes",
|
||||||
|
"reference": "https://github.com/gitmylo/ComfyUI-audio-nodes",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/gitmylo/ComfyUI-audio-nodes"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Various nodes related to audio."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "aicuai",
|
||||||
|
"title": "aicu-comfyui-stability-ai-api",
|
||||||
|
"reference": "https://github.com/aicuai/aicu-comfyui-stability-ai-api",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/aicuai/aicu-comfyui-stability-ai-api"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "This repository contains custom nodes for Stability AI API which supports SD3.0 and 3.5."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "benda1989",
|
||||||
|
"title": "CosyVoice2 for ComfyUI",
|
||||||
|
"reference": "https://github.com/benda1989/CosyVoice2_ComfyUI",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/benda1989/CosyVoice2_ComfyUI"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A plugin of ComfyUI for CosyVoice2, one component for text to Sonic Video"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "benda1989",
|
||||||
|
"title": "GKK·Sonic",
|
||||||
|
"reference": "https://github.com/benda1989/Sonic_ComfyUI",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/benda1989/Sonic_ComfyUI"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "a plugin of ComfyUI for Long Sonic"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "morgan55555",
|
||||||
|
"title": "ComfyUI Lock Mode",
|
||||||
|
"reference": "https://github.com/morgan55555/comfyui-lock-mode",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/morgan55555/comfyui-lock-mode"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Lock Mode feature for ComfyUI. Make simple no-code UI easily."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "pathway8-sudo",
|
||||||
|
"title": "ComfyUI-Pathway-CutPNG-Node",
|
||||||
|
"reference": "https://github.com/pathway8-sudo/ComfyUI-Pathway-CutPNG-Node",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/pathway8-sudo/ComfyUI-Pathway-CutPNG-Node"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Custom ComfyUI node that uses BRIA RMBG v1.4 for background removal and PNG cutting."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "crave33",
|
||||||
|
"title": "RenesStuffDanboruTagGet",
|
||||||
|
"reference": "https://github.com/crave33/RenesStuffDanboruTagGet",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/crave33/RenesStuffDanboruTagGet"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "generate tags / prompt from danboru image_id input"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "MeeeyoAI",
|
||||||
|
"title": "ComfyUI_StringOps",
|
||||||
|
"reference": "https://github.com/MeeeyoAI/ComfyUI_StringOps",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/MeeeyoAI/ComfyUI_StringOps"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "StringOps is a versatile text processing toolkit built for ComfyUI's node-based workflows"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "svetozarov",
|
||||||
|
"title": "AS_GeminiCaptioning Node",
|
||||||
|
"reference": "https://github.com/svetozarov/AS_GeminiCaptioning",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/svetozarov/AS_GeminiCaptioning"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A ComfyUI node that combines an image with simple text parameters to create a prompt, sends it to the Google Gemini API via the google-generativeai SDK, and returns the generated text response along with the original prompt and an execution log"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "Pablerdo",
|
||||||
|
"title": "ComfyUI-MultiCutAndDrag",
|
||||||
|
"reference": "https://github.com/Pablerdo/ComfyUI-MultiCutAndDrag",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/Pablerdo/ComfyUI-MultiCutAndDrag"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Cut and and drag that allows you to cut and drag multiple images on a path"
|
||||||
|
},
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -21156,7 +21533,7 @@
|
|||||||
"https://raw.githubusercontent.com/tudal/Hakkun-ComfyUI-nodes/main/hakkun_nodes.py"
|
"https://raw.githubusercontent.com/tudal/Hakkun-ComfyUI-nodes/main/hakkun_nodes.py"
|
||||||
],
|
],
|
||||||
"install_type": "copy",
|
"install_type": "copy",
|
||||||
"description": "Nodes: Prompt parser. ComfyUI extra nodes. Mostly prompt parsing."
|
"description": "Mainly its prompt generating by custom syntax. Prompt Parser, Prompt tags, Random Line, Calculate Upscale, Image size to string, Type Converter, Image Resize To Height/Width, Load Random Image, Load Text"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"author": "SadaleNet",
|
"author": "SadaleNet",
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -154,14 +154,27 @@ def switch_to_default_branch(repo):
|
|||||||
repo.git.checkout(default_branch)
|
repo.git.checkout(default_branch)
|
||||||
return True
|
return True
|
||||||
except:
|
except:
|
||||||
|
# try checkout master
|
||||||
|
# try checkout main if failed
|
||||||
try:
|
try:
|
||||||
repo.git.checkout(repo.heads.master)
|
repo.git.checkout(repo.heads.master)
|
||||||
|
return True
|
||||||
except:
|
except:
|
||||||
try:
|
try:
|
||||||
if remote_name is not None:
|
if remote_name is not None:
|
||||||
repo.git.checkout('-b', 'master', f'{remote_name}/master')
|
repo.git.checkout('-b', 'master', f'{remote_name}/master')
|
||||||
|
return True
|
||||||
except:
|
except:
|
||||||
pass
|
try:
|
||||||
|
repo.git.checkout(repo.heads.main)
|
||||||
|
return True
|
||||||
|
except:
|
||||||
|
try:
|
||||||
|
if remote_name is not None:
|
||||||
|
repo.git.checkout('-b', 'main', f'{remote_name}/main')
|
||||||
|
return True
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
|
||||||
print("[ComfyUI Manager] Failed to switch to the default branch")
|
print("[ComfyUI Manager] Failed to switch to the default branch")
|
||||||
return False
|
return False
|
||||||
|
|||||||
5649
github-stats.json
5649
github-stats.json
File diff suppressed because it is too large
Load Diff
@@ -2,6 +2,9 @@ import os
|
|||||||
import configparser
|
import configparser
|
||||||
|
|
||||||
|
|
||||||
|
GITHUB_ENDPOINT = os.getenv('GITHUB_ENDPOINT')
|
||||||
|
|
||||||
|
|
||||||
def is_git_repo(path: str) -> bool:
|
def is_git_repo(path: str) -> bool:
|
||||||
""" Check if the path is a git repository. """
|
""" Check if the path is a git repository. """
|
||||||
# NOTE: Checking it through `git.Repo` must be avoided.
|
# NOTE: Checking it through `git.Repo` must be avoided.
|
||||||
@@ -37,7 +40,8 @@ def git_url(fullpath):
|
|||||||
if not os.path.exists(git_config_path):
|
if not os.path.exists(git_config_path):
|
||||||
return None
|
return None
|
||||||
|
|
||||||
config = configparser.ConfigParser()
|
# Set `strict=False` to allow duplicate `vscode-merge-base` sections, addressing <https://github.com/ltdrdata/ComfyUI-Manager/issues/1529>
|
||||||
|
config = configparser.ConfigParser(strict=False)
|
||||||
config.read(git_config_path)
|
config.read(git_config_path)
|
||||||
|
|
||||||
for k, v in config.items():
|
for k, v in config.items():
|
||||||
@@ -46,16 +50,36 @@ def git_url(fullpath):
|
|||||||
|
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
|
||||||
def normalize_url(url) -> str:
|
def normalize_url(url) -> str:
|
||||||
url = url.replace("git@github.com:", "https://github.com/")
|
github_id = normalize_to_github_id(url)
|
||||||
if url.endswith('.git'):
|
if github_id is not None:
|
||||||
url = url[:-4]
|
url = f"https://github.com/{github_id}"
|
||||||
|
|
||||||
return url
|
return url
|
||||||
|
|
||||||
def normalize_url_http(url) -> str:
|
|
||||||
url = url.replace("https://github.com/", "git@github.com:")
|
def normalize_to_github_id(url) -> str:
|
||||||
if url.endswith('.git'):
|
if 'github' in url or (GITHUB_ENDPOINT is not None and GITHUB_ENDPOINT in url):
|
||||||
url = url[:-4]
|
author = os.path.basename(os.path.dirname(url))
|
||||||
|
|
||||||
|
if author.startswith('git@github.com:'):
|
||||||
|
author = author.split(':')[1]
|
||||||
|
|
||||||
|
repo_name = os.path.basename(url)
|
||||||
|
if repo_name.endswith('.git'):
|
||||||
|
repo_name = repo_name[:-4]
|
||||||
|
|
||||||
|
return f"{author}/{repo_name}"
|
||||||
|
|
||||||
|
return None
|
||||||
|
|
||||||
|
|
||||||
|
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
|
return url
|
||||||
|
|
||||||
@@ -42,7 +42,7 @@ import manager_downloader
|
|||||||
from node_package import InstalledNodePackage
|
from node_package import InstalledNodePackage
|
||||||
|
|
||||||
|
|
||||||
version_code = [3, 23]
|
version_code = [3, 26]
|
||||||
version_str = f"V{version_code[0]}.{version_code[1]}" + (f'.{version_code[2]}' if len(version_code) > 2 else '')
|
version_str = f"V{version_code[0]}.{version_code[1]}" + (f'.{version_code[2]}' if len(version_code) > 2 else '')
|
||||||
|
|
||||||
|
|
||||||
@@ -505,6 +505,8 @@ class UnifiedManager:
|
|||||||
def resolve_from_path(self, fullpath):
|
def resolve_from_path(self, fullpath):
|
||||||
url = git_utils.git_url(fullpath)
|
url = git_utils.git_url(fullpath)
|
||||||
if url:
|
if url:
|
||||||
|
url = git_utils.normalize_url(url)
|
||||||
|
|
||||||
cnr = self.get_cnr_by_repo(url)
|
cnr = self.get_cnr_by_repo(url)
|
||||||
commit_hash = git_utils.get_commit_hash(fullpath)
|
commit_hash = git_utils.get_commit_hash(fullpath)
|
||||||
if cnr:
|
if cnr:
|
||||||
@@ -536,6 +538,8 @@ class UnifiedManager:
|
|||||||
|
|
||||||
if node_package.is_disabled and node_package.is_unknown:
|
if node_package.is_disabled and node_package.is_unknown:
|
||||||
url = git_utils.git_url(node_package.fullpath)
|
url = git_utils.git_url(node_package.fullpath)
|
||||||
|
if url is not None:
|
||||||
|
url = git_utils.normalize_url(url)
|
||||||
self.unknown_inactive_nodes[node_package.id] = (url, node_package.fullpath)
|
self.unknown_inactive_nodes[node_package.id] = (url, node_package.fullpath)
|
||||||
|
|
||||||
if node_package.is_disabled and node_package.is_nightly:
|
if node_package.is_disabled and node_package.is_nightly:
|
||||||
@@ -546,6 +550,8 @@ class UnifiedManager:
|
|||||||
|
|
||||||
if node_package.is_enabled and node_package.is_unknown:
|
if node_package.is_enabled and node_package.is_unknown:
|
||||||
url = git_utils.git_url(node_package.fullpath)
|
url = git_utils.git_url(node_package.fullpath)
|
||||||
|
if url is not None:
|
||||||
|
url = git_utils.normalize_url(url)
|
||||||
self.unknown_active_nodes[node_package.id] = (url, node_package.fullpath)
|
self.unknown_active_nodes[node_package.id] = (url, node_package.fullpath)
|
||||||
|
|
||||||
if node_package.is_from_cnr and node_package.is_disabled:
|
if node_package.is_from_cnr and node_package.is_disabled:
|
||||||
@@ -1057,8 +1063,8 @@ class UnifiedManager:
|
|||||||
|
|
||||||
# update cache
|
# update cache
|
||||||
if version_spec == 'unknown':
|
if version_spec == 'unknown':
|
||||||
|
self.unknown_active_nodes[node_id] = self.unknown_inactive_nodes[node_id][0], to_path
|
||||||
del self.unknown_inactive_nodes[node_id]
|
del self.unknown_inactive_nodes[node_id]
|
||||||
self.unknown_active_nodes[node_id] = to_path
|
|
||||||
return result.with_target(to_path)
|
return result.with_target(to_path)
|
||||||
elif version_spec == 'nightly':
|
elif version_spec == 'nightly':
|
||||||
del self.nightly_inactive_nodes[node_id]
|
del self.nightly_inactive_nodes[node_id]
|
||||||
@@ -1239,15 +1245,16 @@ class UnifiedManager:
|
|||||||
if url.endswith("/"):
|
if url.endswith("/"):
|
||||||
url = url[:-1]
|
url = url[:-1]
|
||||||
try:
|
try:
|
||||||
print(f"Download: git clone '{url}'")
|
|
||||||
|
|
||||||
# Clone the repository from the remote URL
|
# Clone the repository from the remote URL
|
||||||
|
clone_url = git_utils.get_url_for_clone(url)
|
||||||
|
print(f"Download: git clone '{clone_url}'")
|
||||||
|
|
||||||
if not instant_execution and platform.system() == 'Windows':
|
if not instant_execution and platform.system() == 'Windows':
|
||||||
res = manager_funcs.run_script([sys.executable, git_script_path, "--clone", get_default_custom_nodes_path(), url, repo_path], cwd=get_default_custom_nodes_path())
|
res = manager_funcs.run_script([sys.executable, git_script_path, "--clone", get_default_custom_nodes_path(), clone_url, repo_path], cwd=get_default_custom_nodes_path())
|
||||||
if res != 0:
|
if res != 0:
|
||||||
return result.fail(f"Failed to clone repo: {url}")
|
return result.fail(f"Failed to clone repo: {clone_url}")
|
||||||
else:
|
else:
|
||||||
repo = git.Repo.clone_from(url, repo_path, recursive=True, progress=GitProgress())
|
repo = git.Repo.clone_from(clone_url, repo_path, recursive=True, progress=GitProgress())
|
||||||
repo.git.clear_cache()
|
repo.git.clear_cache()
|
||||||
repo.close()
|
repo.close()
|
||||||
|
|
||||||
@@ -1398,7 +1405,7 @@ class UnifiedManager:
|
|||||||
res = self.repo_install(repo_url, to_path, instant_execution=instant_execution, no_deps=no_deps, return_postinstall=return_postinstall)
|
res = self.repo_install(repo_url, to_path, instant_execution=instant_execution, no_deps=no_deps, return_postinstall=return_postinstall)
|
||||||
if res.result:
|
if res.result:
|
||||||
if version_spec == 'unknown':
|
if version_spec == 'unknown':
|
||||||
self.unknown_active_nodes[node_id] = to_path
|
self.unknown_active_nodes[node_id] = repo_url, to_path
|
||||||
elif version_spec == 'nightly':
|
elif version_spec == 'nightly':
|
||||||
cnr_utils.generate_cnr_id(to_path, node_id)
|
cnr_utils.generate_cnr_id(to_path, node_id)
|
||||||
self.active_nodes[node_id] = 'nightly', to_path
|
self.active_nodes[node_id] = 'nightly', to_path
|
||||||
@@ -1465,7 +1472,7 @@ def identify_node_pack_from_path(fullpath):
|
|||||||
# cnr
|
# cnr
|
||||||
cnr = cnr_utils.read_cnr_info(fullpath)
|
cnr = cnr_utils.read_cnr_info(fullpath)
|
||||||
if cnr is not None:
|
if cnr is not None:
|
||||||
return module_name, cnr['version'], cnr['id']
|
return module_name, cnr['version'], cnr['id'], None
|
||||||
|
|
||||||
return None
|
return None
|
||||||
else:
|
else:
|
||||||
@@ -1473,10 +1480,18 @@ def identify_node_pack_from_path(fullpath):
|
|||||||
cnr_id = cnr_utils.read_cnr_id(fullpath)
|
cnr_id = cnr_utils.read_cnr_id(fullpath)
|
||||||
commit_hash = git_utils.get_commit_hash(fullpath)
|
commit_hash = git_utils.get_commit_hash(fullpath)
|
||||||
|
|
||||||
|
github_id = git_utils.normalize_to_github_id(repo_url)
|
||||||
|
if github_id is None:
|
||||||
|
try:
|
||||||
|
github_id = os.path.basename(repo_url)
|
||||||
|
except:
|
||||||
|
logging.warning(f"[ComfyUI-Manager] unexpected repo url: {repo_url}")
|
||||||
|
github_id = module_name
|
||||||
|
|
||||||
if cnr_id is not None:
|
if cnr_id is not None:
|
||||||
return module_name, commit_hash, cnr_id
|
return module_name, commit_hash, cnr_id, github_id
|
||||||
else:
|
else:
|
||||||
return module_name, commit_hash, ''
|
return module_name, commit_hash, '', github_id
|
||||||
|
|
||||||
|
|
||||||
def get_installed_node_packs():
|
def get_installed_node_packs():
|
||||||
@@ -1494,7 +1509,7 @@ def get_installed_node_packs():
|
|||||||
|
|
||||||
is_disabled = not y.endswith('.disabled')
|
is_disabled = not y.endswith('.disabled')
|
||||||
|
|
||||||
res[info[0]] = { 'ver': info[1], 'cnr_id': info[2], 'enabled': is_disabled }
|
res[info[0]] = { 'ver': info[1], 'cnr_id': info[2], 'aux_id': info[3], 'enabled': is_disabled }
|
||||||
|
|
||||||
disabled_dirs = os.path.join(x, '.disabled')
|
disabled_dirs = os.path.join(x, '.disabled')
|
||||||
if os.path.exists(disabled_dirs):
|
if os.path.exists(disabled_dirs):
|
||||||
@@ -1507,7 +1522,7 @@ def get_installed_node_packs():
|
|||||||
if info is None:
|
if info is None:
|
||||||
continue
|
continue
|
||||||
|
|
||||||
res[info[0]] = { 'ver': info[1], 'cnr_id': info[2], 'enabled': False }
|
res[info[0]] = { 'ver': info[1], 'cnr_id': info[2], 'aux_id': info[3], 'enabled': False }
|
||||||
|
|
||||||
return res
|
return res
|
||||||
|
|
||||||
@@ -1563,7 +1578,7 @@ manager_funcs = ManagerFuncs()
|
|||||||
|
|
||||||
|
|
||||||
def write_config():
|
def write_config():
|
||||||
config = configparser.ConfigParser()
|
config = configparser.ConfigParser(strict=False)
|
||||||
|
|
||||||
config['default'] = {
|
config['default'] = {
|
||||||
'preview_method': manager_funcs.get_current_preview_method(),
|
'preview_method': manager_funcs.get_current_preview_method(),
|
||||||
@@ -1574,6 +1589,7 @@ def write_config():
|
|||||||
'bypass_ssl': get_config()['bypass_ssl'],
|
'bypass_ssl': get_config()['bypass_ssl'],
|
||||||
"file_logging": get_config()['file_logging'],
|
"file_logging": get_config()['file_logging'],
|
||||||
'component_policy': get_config()['component_policy'],
|
'component_policy': get_config()['component_policy'],
|
||||||
|
'update_policy': get_config()['update_policy'],
|
||||||
'windows_selector_event_loop_policy': get_config()['windows_selector_event_loop_policy'],
|
'windows_selector_event_loop_policy': get_config()['windows_selector_event_loop_policy'],
|
||||||
'model_download_by_agent': get_config()['model_download_by_agent'],
|
'model_download_by_agent': get_config()['model_download_by_agent'],
|
||||||
'downgrade_blacklist': get_config()['downgrade_blacklist'],
|
'downgrade_blacklist': get_config()['downgrade_blacklist'],
|
||||||
@@ -1593,7 +1609,7 @@ def write_config():
|
|||||||
|
|
||||||
def read_config():
|
def read_config():
|
||||||
try:
|
try:
|
||||||
config = configparser.ConfigParser()
|
config = configparser.ConfigParser(strict=False)
|
||||||
config.read(manager_config_path)
|
config.read(manager_config_path)
|
||||||
default_conf = config['default']
|
default_conf = config['default']
|
||||||
manager_util.use_uv = default_conf['use_uv'].lower() == 'true' if 'use_uv' in default_conf else False
|
manager_util.use_uv = default_conf['use_uv'].lower() == 'true' if 'use_uv' in default_conf else False
|
||||||
@@ -1612,6 +1628,7 @@ def read_config():
|
|||||||
'bypass_ssl': get_bool('bypass_ssl', False),
|
'bypass_ssl': get_bool('bypass_ssl', False),
|
||||||
'file_logging': get_bool('file_logging', True),
|
'file_logging': get_bool('file_logging', True),
|
||||||
'component_policy': default_conf.get('component_policy', 'workflow').lower(),
|
'component_policy': default_conf.get('component_policy', 'workflow').lower(),
|
||||||
|
'update_policy': default_conf.get('update_policy', 'stable-comfyui').lower(),
|
||||||
'windows_selector_event_loop_policy': get_bool('windows_selector_event_loop_policy', False),
|
'windows_selector_event_loop_policy': get_bool('windows_selector_event_loop_policy', False),
|
||||||
'model_download_by_agent': get_bool('model_download_by_agent', False),
|
'model_download_by_agent': get_bool('model_download_by_agent', False),
|
||||||
'downgrade_blacklist': default_conf.get('downgrade_blacklist', '').lower(),
|
'downgrade_blacklist': default_conf.get('downgrade_blacklist', '').lower(),
|
||||||
@@ -1634,6 +1651,7 @@ def read_config():
|
|||||||
'bypass_ssl': False,
|
'bypass_ssl': False,
|
||||||
'file_logging': True,
|
'file_logging': True,
|
||||||
'component_policy': 'workflow',
|
'component_policy': 'workflow',
|
||||||
|
'update_policy': 'stable-comfyui',
|
||||||
'windows_selector_event_loop_policy': False,
|
'windows_selector_event_loop_policy': False,
|
||||||
'model_download_by_agent': False,
|
'model_download_by_agent': False,
|
||||||
'downgrade_blacklist': '',
|
'downgrade_blacklist': '',
|
||||||
@@ -1685,14 +1703,27 @@ def switch_to_default_branch(repo):
|
|||||||
repo.git.checkout(default_branch)
|
repo.git.checkout(default_branch)
|
||||||
return True
|
return True
|
||||||
except:
|
except:
|
||||||
|
# try checkout master
|
||||||
|
# try checkout main if failed
|
||||||
try:
|
try:
|
||||||
repo.git.checkout(repo.heads.master)
|
repo.git.checkout(repo.heads.master)
|
||||||
|
return True
|
||||||
except:
|
except:
|
||||||
try:
|
try:
|
||||||
if remote_name is not None:
|
if remote_name is not None:
|
||||||
repo.git.checkout('-b', 'master', f'{remote_name}/master')
|
repo.git.checkout('-b', 'master', f'{remote_name}/master')
|
||||||
|
return True
|
||||||
except:
|
except:
|
||||||
pass
|
try:
|
||||||
|
repo.git.checkout(repo.heads.main)
|
||||||
|
return True
|
||||||
|
except:
|
||||||
|
try:
|
||||||
|
if remote_name is not None:
|
||||||
|
repo.git.checkout('-b', 'main', f'{remote_name}/main')
|
||||||
|
return True
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
|
||||||
print("[ComfyUI Manager] Failed to switch to the default branch")
|
print("[ComfyUI Manager] Failed to switch to the default branch")
|
||||||
return False
|
return False
|
||||||
@@ -1726,7 +1757,7 @@ def try_install_script(url, repo_path, install_cmd, instant_execution=False):
|
|||||||
|
|
||||||
if platform.system() != "Windows":
|
if platform.system() != "Windows":
|
||||||
try:
|
try:
|
||||||
if comfy_ui_commit_datetime.date() < comfy_ui_required_commit_datetime.date():
|
if not os.environ.get('__COMFYUI_DESKTOP_VERSION__') and comfy_ui_commit_datetime.date() < comfy_ui_required_commit_datetime.date():
|
||||||
print("\n\n###################################################################")
|
print("\n\n###################################################################")
|
||||||
print(f"[WARN] ComfyUI-Manager: Your ComfyUI version ({comfy_ui_revision})[{comfy_ui_commit_datetime.date()}] is too old. Please update to the latest version.")
|
print(f"[WARN] ComfyUI-Manager: Your ComfyUI version ({comfy_ui_revision})[{comfy_ui_commit_datetime.date()}] is too old. Please update to the latest version.")
|
||||||
print("[WARN] The extension installation feature may not work properly in the current installed ComfyUI version on Windows environment.")
|
print("[WARN] The extension installation feature may not work properly in the current installed ComfyUI version on Windows environment.")
|
||||||
@@ -2043,12 +2074,14 @@ async def gitclone_install(url, instant_execution=False, msg_prefix='', no_deps=
|
|||||||
print(f"CLONE into '{repo_path}'")
|
print(f"CLONE into '{repo_path}'")
|
||||||
|
|
||||||
# Clone the repository from the remote URL
|
# Clone the repository from the remote URL
|
||||||
|
clone_url = git_utils.get_url_for_clone(url)
|
||||||
|
|
||||||
if not instant_execution and platform.system() == 'Windows':
|
if not instant_execution and platform.system() == 'Windows':
|
||||||
res = manager_funcs.run_script([sys.executable, git_script_path, "--clone", get_default_custom_nodes_path(), url, repo_path], cwd=get_default_custom_nodes_path())
|
res = manager_funcs.run_script([sys.executable, git_script_path, "--clone", get_default_custom_nodes_path(), clone_url, repo_path], cwd=get_default_custom_nodes_path())
|
||||||
if res != 0:
|
if res != 0:
|
||||||
return result.fail(f"Failed to clone '{url}' into '{repo_path}'")
|
return result.fail(f"Failed to clone '{clone_url}' into '{repo_path}'")
|
||||||
else:
|
else:
|
||||||
repo = git.Repo.clone_from(url, repo_path, recursive=True, progress=GitProgress())
|
repo = git.Repo.clone_from(clone_url, repo_path, recursive=True, progress=GitProgress())
|
||||||
repo.git.clear_cache()
|
repo.git.clear_cache()
|
||||||
repo.close()
|
repo.close()
|
||||||
|
|
||||||
@@ -2342,6 +2375,32 @@ def gitclone_update(files, instant_execution=False, skip_script=False, msg_prefi
|
|||||||
return True
|
return True
|
||||||
|
|
||||||
|
|
||||||
|
def update_to_stable_comfyui(repo_path):
|
||||||
|
try:
|
||||||
|
repo = git.Repo(repo_path)
|
||||||
|
repo.git.checkout(repo.heads.master)
|
||||||
|
versions, current_tag, _ = get_comfyui_versions(repo)
|
||||||
|
|
||||||
|
if len(versions) == 0 or (len(versions) == 1 and versions[0] == 'nightly'):
|
||||||
|
logging.info("[ComfyUI-Manager] Unable to update to the stable ComfyUI version.")
|
||||||
|
return "fail", None
|
||||||
|
|
||||||
|
if versions[0] == 'nightly':
|
||||||
|
latest_tag = versions[1]
|
||||||
|
else:
|
||||||
|
latest_tag = versions[0]
|
||||||
|
|
||||||
|
if current_tag == latest_tag:
|
||||||
|
return "skip", None
|
||||||
|
else:
|
||||||
|
logging.info(f"[ComfyUI-Manager] Updating ComfyUI: {current_tag} -> {latest_tag}")
|
||||||
|
repo.git.checkout(latest_tag)
|
||||||
|
return 'updated', latest_tag
|
||||||
|
except:
|
||||||
|
traceback.print_exc()
|
||||||
|
return "fail", None
|
||||||
|
|
||||||
|
|
||||||
def update_path(repo_path, instant_execution=False, no_deps=False):
|
def update_path(repo_path, instant_execution=False, no_deps=False):
|
||||||
if not os.path.exists(os.path.join(repo_path, '.git')):
|
if not os.path.exists(os.path.join(repo_path, '.git')):
|
||||||
return "fail"
|
return "fail"
|
||||||
@@ -2349,9 +2408,12 @@ def update_path(repo_path, instant_execution=False, no_deps=False):
|
|||||||
# version check
|
# version check
|
||||||
repo = git.Repo(repo_path)
|
repo = git.Repo(repo_path)
|
||||||
|
|
||||||
|
is_switched = False
|
||||||
if repo.head.is_detached:
|
if repo.head.is_detached:
|
||||||
if not switch_to_default_branch(repo):
|
if not switch_to_default_branch(repo):
|
||||||
return "fail"
|
return "fail"
|
||||||
|
else:
|
||||||
|
is_switched = True
|
||||||
|
|
||||||
current_branch = repo.active_branch
|
current_branch = repo.active_branch
|
||||||
branch_name = current_branch.name
|
branch_name = current_branch.name
|
||||||
@@ -2390,6 +2452,8 @@ def update_path(repo_path, instant_execution=False, no_deps=False):
|
|||||||
git_pull(repo_path)
|
git_pull(repo_path)
|
||||||
execute_install_script("ComfyUI", repo_path, instant_execution=instant_execution, no_deps=no_deps)
|
execute_install_script("ComfyUI", repo_path, instant_execution=instant_execution, no_deps=no_deps)
|
||||||
return "updated"
|
return "updated"
|
||||||
|
elif is_switched:
|
||||||
|
return "updated"
|
||||||
else:
|
else:
|
||||||
return "skipped"
|
return "skipped"
|
||||||
|
|
||||||
@@ -2700,9 +2764,6 @@ async def extract_nodes_from_workflow(filepath, mode='local', channel_url='defau
|
|||||||
if ext == 'https://github.com/comfyanonymous/ComfyUI':
|
if ext == 'https://github.com/comfyanonymous/ComfyUI':
|
||||||
pass
|
pass
|
||||||
elif ext is not None:
|
elif ext is not None:
|
||||||
if 'Fooocus' in ext:
|
|
||||||
print(f">> {node_name}")
|
|
||||||
|
|
||||||
used_exts.add(ext)
|
used_exts.add(ext)
|
||||||
else:
|
else:
|
||||||
unknown_nodes.add(node_name)
|
unknown_nodes.add(node_name)
|
||||||
@@ -2973,7 +3034,14 @@ async def restore_snapshot(snapshot_path, git_helper_extras=None):
|
|||||||
print("cm-cli: unexpected [0001]")
|
print("cm-cli: unexpected [0001]")
|
||||||
|
|
||||||
# for nightly restore
|
# for nightly restore
|
||||||
git_info = info.get('git_custom_nodes')
|
_git_info = info.get('git_custom_nodes')
|
||||||
|
git_info = {}
|
||||||
|
|
||||||
|
# normalize github repo
|
||||||
|
for k, v in _git_info.items():
|
||||||
|
norm_k = git_utils.normalize_url(k)
|
||||||
|
git_info[norm_k] = v
|
||||||
|
|
||||||
if git_info is not None:
|
if git_info is not None:
|
||||||
todo_disable = []
|
todo_disable = []
|
||||||
todo_enable = []
|
todo_enable = []
|
||||||
@@ -2986,20 +3054,13 @@ async def restore_snapshot(snapshot_path, git_helper_extras=None):
|
|||||||
|
|
||||||
if v[0] == 'nightly' and cnr_repo_map.get(k):
|
if v[0] == 'nightly' and cnr_repo_map.get(k):
|
||||||
repo_url = cnr_repo_map.get(k)
|
repo_url = cnr_repo_map.get(k)
|
||||||
|
normalized_url = git_utils.normalize_url(repo_url)
|
||||||
|
|
||||||
normalized_url1 = git_utils.normalize_url(repo_url)
|
if normalized_url not in git_info:
|
||||||
normalized_url2 = git_utils.normalize_url_http(repo_url)
|
|
||||||
|
|
||||||
if normalized_url1 not in git_info and normalized_url2 not in git_info:
|
|
||||||
todo_disable.append(k)
|
todo_disable.append(k)
|
||||||
else:
|
else:
|
||||||
if normalized_url1 in git_info:
|
commit_hash = git_info[normalized_url]['hash']
|
||||||
commit_hash = git_info[normalized_url1]['hash']
|
todo_checkout.append((v[1], commit_hash))
|
||||||
todo_checkout.append((v[1], commit_hash))
|
|
||||||
|
|
||||||
if normalized_url2 in git_info:
|
|
||||||
commit_hash = git_info[normalized_url2]['hash']
|
|
||||||
todo_checkout.append((v[1], commit_hash))
|
|
||||||
|
|
||||||
for k, v in unified_manager.nightly_inactive_nodes.items():
|
for k, v in unified_manager.nightly_inactive_nodes.items():
|
||||||
if 'comfyui-manager' in k:
|
if 'comfyui-manager' in k:
|
||||||
@@ -3007,18 +3068,12 @@ async def restore_snapshot(snapshot_path, git_helper_extras=None):
|
|||||||
|
|
||||||
if cnr_repo_map.get(k):
|
if cnr_repo_map.get(k):
|
||||||
repo_url = cnr_repo_map.get(k)
|
repo_url = cnr_repo_map.get(k)
|
||||||
normalized_url1 = git_utils.normalize_url(repo_url)
|
normalized_url = git_utils.normalize_url(repo_url)
|
||||||
normalized_url2 = git_utils.normalize_url_http(repo_url)
|
|
||||||
|
|
||||||
if normalized_url1 in git_info:
|
if normalized_url in git_info:
|
||||||
commit_hash = git_info[normalized_url1]['hash']
|
commit_hash = git_info[normalized_url]['hash']
|
||||||
todo_enable.append((k, commit_hash))
|
todo_enable.append((k, commit_hash))
|
||||||
processed_urls.append(normalized_url1)
|
processed_urls.append(normalized_url)
|
||||||
|
|
||||||
if normalized_url2 in git_info:
|
|
||||||
commit_hash = git_info[normalized_url2]['hash']
|
|
||||||
todo_enable.append((k, commit_hash))
|
|
||||||
processed_urls.append(normalized_url2)
|
|
||||||
|
|
||||||
for x in todo_disable:
|
for x in todo_disable:
|
||||||
unified_manager.unified_disable(x, False)
|
unified_manager.unified_disable(x, False)
|
||||||
@@ -3071,21 +3126,14 @@ async def restore_snapshot(snapshot_path, git_helper_extras=None):
|
|||||||
if repo_url is None:
|
if repo_url is None:
|
||||||
continue
|
continue
|
||||||
|
|
||||||
normalized_url1 = git_utils.normalize_url(repo_url)
|
normalized_url = git_utils.normalize_url(repo_url)
|
||||||
normalized_url2 = git_utils.normalize_url_http(repo_url)
|
|
||||||
|
|
||||||
if normalized_url1 not in git_info and normalized_url2 not in git_info:
|
if normalized_url not in git_info:
|
||||||
todo_disable.append(k2)
|
todo_disable.append(k2)
|
||||||
else:
|
else:
|
||||||
if normalized_url1 in git_info:
|
commit_hash = git_info[normalized_url]['hash']
|
||||||
commit_hash = git_info[normalized_url1]['hash']
|
todo_checkout.append((k2, commit_hash))
|
||||||
todo_checkout.append((k2, commit_hash))
|
processed_urls.append(normalized_url)
|
||||||
processed_urls.append(normalized_url1)
|
|
||||||
|
|
||||||
if normalized_url2 in git_info:
|
|
||||||
commit_hash = git_info[normalized_url2]['hash']
|
|
||||||
todo_checkout.append((k2, commit_hash))
|
|
||||||
processed_urls.append(normalized_url2)
|
|
||||||
|
|
||||||
for k2, v2 in unified_manager.unknown_inactive_nodes.items():
|
for k2, v2 in unified_manager.unknown_inactive_nodes.items():
|
||||||
repo_url = resolve_giturl_from_path(v2[1])
|
repo_url = resolve_giturl_from_path(v2[1])
|
||||||
@@ -3093,18 +3141,12 @@ async def restore_snapshot(snapshot_path, git_helper_extras=None):
|
|||||||
if repo_url is None:
|
if repo_url is None:
|
||||||
continue
|
continue
|
||||||
|
|
||||||
normalized_url1 = git_utils.normalize_url(repo_url)
|
normalized_url = git_utils.normalize_url(repo_url)
|
||||||
normalized_url2 = git_utils.normalize_url_http(repo_url)
|
|
||||||
|
|
||||||
if normalized_url1 in git_info:
|
if normalized_url in git_info:
|
||||||
commit_hash = git_info[normalized_url1]['hash']
|
commit_hash = git_info[normalized_url]['hash']
|
||||||
todo_enable.append((k2, commit_hash))
|
todo_enable.append((k2, commit_hash))
|
||||||
processed_urls.append(normalized_url1)
|
processed_urls.append(normalized_url)
|
||||||
|
|
||||||
if normalized_url2 in git_info:
|
|
||||||
commit_hash = git_info[normalized_url2]['hash']
|
|
||||||
todo_enable.append((k2, commit_hash))
|
|
||||||
processed_urls.append(normalized_url2)
|
|
||||||
|
|
||||||
for x in todo_disable:
|
for x in todo_disable:
|
||||||
unified_manager.unified_disable(x, True)
|
unified_manager.unified_disable(x, True)
|
||||||
@@ -3190,17 +3232,26 @@ async def check_need_to_migrate():
|
|||||||
need_to_migrate = True
|
need_to_migrate = True
|
||||||
|
|
||||||
|
|
||||||
def get_comfyui_versions():
|
def get_comfyui_versions(repo=None):
|
||||||
repo = git.Repo(comfy_path)
|
if repo is None:
|
||||||
versions = [x.name for x in repo.tags if x.name.startswith('v')]
|
repo = git.Repo(comfy_path)
|
||||||
versions.reverse() # nearest tag
|
|
||||||
|
|
||||||
|
try:
|
||||||
|
remote = get_remote_name(repo)
|
||||||
|
repo.remotes[remote].fetch()
|
||||||
|
except:
|
||||||
|
logging.error("[ComfyUI-Manager] Failed to fetch ComfyUI")
|
||||||
|
|
||||||
|
versions = [x.name for x in repo.tags if x.name.startswith('v')]
|
||||||
|
|
||||||
|
# nearest tag
|
||||||
|
versions = sorted(versions, key=lambda v: repo.git.log('-1', '--format=%ct', v), reverse=True)
|
||||||
versions = versions[:4]
|
versions = versions[:4]
|
||||||
|
|
||||||
current_tag = repo.git.describe('--tags')
|
current_tag = repo.git.describe('--tags')
|
||||||
|
|
||||||
if current_tag not in versions:
|
if current_tag not in versions:
|
||||||
versions = sorted(versions + [current_tag], reverse=True)
|
versions = sorted(versions + [current_tag], key=lambda v: repo.git.log('-1', '--format=%ct', v), reverse=True)
|
||||||
versions = versions[:4]
|
versions = versions[:4]
|
||||||
|
|
||||||
main_branch = repo.heads.master
|
main_branch = repo.heads.master
|
||||||
@@ -3213,16 +3264,18 @@ def get_comfyui_versions():
|
|||||||
versions[0] = 'nightly'
|
versions[0] = 'nightly'
|
||||||
current_tag = 'nightly'
|
current_tag = 'nightly'
|
||||||
|
|
||||||
return versions, current_tag
|
return versions, current_tag, latest_tag
|
||||||
|
|
||||||
|
|
||||||
def switch_comfyui(tag):
|
def switch_comfyui(tag):
|
||||||
repo = git.Repo(comfy_path)
|
repo = git.Repo(comfy_path)
|
||||||
|
|
||||||
if tag == 'nightly':
|
if tag == 'nightly':
|
||||||
repo.git.checkout('main')
|
repo.git.checkout('master')
|
||||||
repo.remotes.origin.pull()
|
tracking_branch = repo.active_branch.tracking_branch()
|
||||||
print("[ComfyUI-Manager] ComfyUI version is switched to the latest 'main' version")
|
remote_name = tracking_branch.remote_name
|
||||||
|
repo.remotes[remote_name].pull()
|
||||||
|
print("[ComfyUI-Manager] ComfyUI version is switched to the latest 'master' version")
|
||||||
else:
|
else:
|
||||||
repo.git.checkout(tag)
|
repo.git.checkout(tag)
|
||||||
print(f"[ComfyUI-Manager] ComfyUI version is switched to '{tag}'")
|
print(f"[ComfyUI-Manager] ComfyUI version is switched to '{tag}'")
|
||||||
@@ -3237,7 +3290,7 @@ def resolve_giturl_from_path(fullpath):
|
|||||||
if not os.path.exists(git_config_path):
|
if not os.path.exists(git_config_path):
|
||||||
return "unknown"
|
return "unknown"
|
||||||
|
|
||||||
config = configparser.ConfigParser()
|
config = configparser.ConfigParser(strict=False)
|
||||||
config.read(git_config_path)
|
config.read(git_config_path)
|
||||||
|
|
||||||
for k, v in config.items():
|
for k, v in config.items():
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ from tqdm.auto import tqdm
|
|||||||
aria2 = os.getenv('COMFYUI_MANAGER_ARIA2_SERVER')
|
aria2 = os.getenv('COMFYUI_MANAGER_ARIA2_SERVER')
|
||||||
HF_ENDPOINT = os.getenv('HF_ENDPOINT')
|
HF_ENDPOINT = os.getenv('HF_ENDPOINT')
|
||||||
|
|
||||||
|
|
||||||
if aria2 is not None:
|
if aria2 is not None:
|
||||||
secret = os.getenv('COMFYUI_MANAGER_ARIA2_SECRET')
|
secret = os.getenv('COMFYUI_MANAGER_ARIA2_SECRET')
|
||||||
url = urlparse(aria2)
|
url = urlparse(aria2)
|
||||||
|
|||||||
@@ -187,6 +187,8 @@ set_preview_method(core.get_config()['preview_method'])
|
|||||||
def set_component_policy(mode):
|
def set_component_policy(mode):
|
||||||
core.get_config()['component_policy'] = mode
|
core.get_config()['component_policy'] = mode
|
||||||
|
|
||||||
|
def set_update_policy(mode):
|
||||||
|
core.get_config()['update_policy'] = mode
|
||||||
|
|
||||||
def print_comfyui_version():
|
def print_comfyui_version():
|
||||||
global comfy_ui_hash
|
global comfy_ui_hash
|
||||||
@@ -209,7 +211,7 @@ def print_comfyui_version():
|
|||||||
comfyui_tag = core.get_comfyui_tag()
|
comfyui_tag = core.get_comfyui_tag()
|
||||||
|
|
||||||
try:
|
try:
|
||||||
if core.comfy_ui_commit_datetime.date() < core.comfy_ui_required_commit_datetime.date():
|
if not os.environ.get('__COMFYUI_DESKTOP_VERSION__') and core.comfy_ui_commit_datetime.date() < core.comfy_ui_required_commit_datetime.date():
|
||||||
logging.warning(f"\n\n## [WARN] ComfyUI-Manager: Your ComfyUI version ({core.comfy_ui_revision})[{core.comfy_ui_commit_datetime.date()}] is too old. Please update to the latest version. ##\n\n")
|
logging.warning(f"\n\n## [WARN] ComfyUI-Manager: Your ComfyUI version ({core.comfy_ui_revision})[{core.comfy_ui_commit_datetime.date()}] is too old. Please update to the latest version. ##\n\n")
|
||||||
except:
|
except:
|
||||||
pass
|
pass
|
||||||
@@ -452,20 +454,29 @@ async def task_worker():
|
|||||||
|
|
||||||
return {'msg':f"An error occurred while updating '{node_name}'."}
|
return {'msg':f"An error occurred while updating '{node_name}'."}
|
||||||
|
|
||||||
async def do_update_comfyui() -> str:
|
async def do_update_comfyui(is_stable) -> str:
|
||||||
try:
|
try:
|
||||||
repo_path = os.path.dirname(folder_paths.__file__)
|
repo_path = os.path.dirname(folder_paths.__file__)
|
||||||
res = core.update_path(repo_path)
|
latest_tag = None
|
||||||
|
if is_stable:
|
||||||
|
res, latest_tag = core.update_to_stable_comfyui(repo_path)
|
||||||
|
else:
|
||||||
|
res = core.update_path(repo_path)
|
||||||
|
|
||||||
if res == "fail":
|
if res == "fail":
|
||||||
logging.error("ComfyUI update fail: The installed ComfyUI does not have a Git repository.")
|
logging.error("ComfyUI update fail: The installed ComfyUI does not have a Git repository.")
|
||||||
return "The installed ComfyUI does not have a Git repository."
|
return "The installed ComfyUI does not have a Git repository."
|
||||||
elif res == "updated":
|
elif res == "updated":
|
||||||
logging.info("ComfyUI is updated.")
|
if is_stable:
|
||||||
return "success"
|
logging.info("ComfyUI is updated to latest stable version.")
|
||||||
|
return "success-stable-"+latest_tag
|
||||||
|
else:
|
||||||
|
logging.info("ComfyUI is updated to latest nightly version.")
|
||||||
|
return "success-nightly"
|
||||||
else: # skipped
|
else: # skipped
|
||||||
logging.info("ComfyUI is up-to-date.")
|
logging.info("ComfyUI is up-to-date.")
|
||||||
return "skip"
|
return "skip"
|
||||||
|
|
||||||
except Exception:
|
except Exception:
|
||||||
traceback.print_exc()
|
traceback.print_exc()
|
||||||
|
|
||||||
@@ -597,7 +608,7 @@ async def task_worker():
|
|||||||
elif kind == 'update-main':
|
elif kind == 'update-main':
|
||||||
msg = await do_update(item)
|
msg = await do_update(item)
|
||||||
elif kind == 'update-comfyui':
|
elif kind == 'update-comfyui':
|
||||||
msg = await do_update_comfyui()
|
msg = await do_update_comfyui(item[1])
|
||||||
elif kind == 'fix':
|
elif kind == 'fix':
|
||||||
msg = await do_fix(item)
|
msg = await do_fix(item)
|
||||||
elif kind == 'uninstall':
|
elif kind == 'uninstall':
|
||||||
@@ -1337,14 +1348,15 @@ async def update_custom_node(request):
|
|||||||
|
|
||||||
@routes.get("/manager/queue/update_comfyui")
|
@routes.get("/manager/queue/update_comfyui")
|
||||||
async def update_comfyui(request):
|
async def update_comfyui(request):
|
||||||
task_queue.put(("update-comfyui", ('comfyui',)))
|
is_stable = core.get_config()['update_policy'] != 'nightly-comfyui'
|
||||||
|
task_queue.put(("update-comfyui", ('comfyui', is_stable)))
|
||||||
return web.Response(status=200)
|
return web.Response(status=200)
|
||||||
|
|
||||||
|
|
||||||
@routes.get("/comfyui_manager/comfyui_versions")
|
@routes.get("/comfyui_manager/comfyui_versions")
|
||||||
async def comfyui_versions(request):
|
async def comfyui_versions(request):
|
||||||
try:
|
try:
|
||||||
res, current = core.get_comfyui_versions()
|
res, current, latest = core.get_comfyui_versions()
|
||||||
return web.json_response({'versions': res, 'current': current}, status=200, content_type='application/json')
|
return web.json_response({'versions': res, 'current': current}, status=200, content_type='application/json')
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
logging.error(f"ComfyUI update fail: {e}", file=sys.stderr)
|
logging.error(f"ComfyUI update fail: {e}", file=sys.stderr)
|
||||||
@@ -1435,7 +1447,7 @@ async def preview_method(request):
|
|||||||
return web.Response(status=200)
|
return web.Response(status=200)
|
||||||
|
|
||||||
|
|
||||||
@routes.get("/manager/component/policy")
|
@routes.get("/manager/policy/component")
|
||||||
async def component_policy(request):
|
async def component_policy(request):
|
||||||
if "value" in request.rel_url.query:
|
if "value" in request.rel_url.query:
|
||||||
set_component_policy(request.rel_url.query['value'])
|
set_component_policy(request.rel_url.query['value'])
|
||||||
@@ -1446,6 +1458,17 @@ async def component_policy(request):
|
|||||||
return web.Response(status=200)
|
return web.Response(status=200)
|
||||||
|
|
||||||
|
|
||||||
|
@routes.get("/manager/policy/update")
|
||||||
|
async def update_policy(request):
|
||||||
|
if "value" in request.rel_url.query:
|
||||||
|
set_update_policy(request.rel_url.query['value'])
|
||||||
|
core.write_config()
|
||||||
|
else:
|
||||||
|
return web.Response(text=core.get_config()['update_policy'], status=200)
|
||||||
|
|
||||||
|
return web.Response(status=200)
|
||||||
|
|
||||||
|
|
||||||
@routes.get("/manager/channel_url_list")
|
@routes.get("/manager/channel_url_list")
|
||||||
async def channel_url_list(request):
|
async def channel_url_list(request):
|
||||||
channels = core.get_channel_dict()
|
channels = core.get_channel_dict()
|
||||||
@@ -1501,7 +1524,11 @@ async def get_notice(request):
|
|||||||
markdown_content = match.group(1)
|
markdown_content = match.group(1)
|
||||||
version_tag = core.get_comfyui_tag()
|
version_tag = core.get_comfyui_tag()
|
||||||
if version_tag is None:
|
if version_tag is None:
|
||||||
markdown_content += f"<HR>ComfyUI: {core.comfy_ui_revision}[{comfy_ui_hash[:6]}]({core.comfy_ui_commit_datetime.date()})"
|
version_tag = os.environ.get('__COMFYUI_DESKTOP_VERSION__')
|
||||||
|
if version_tag is not None:
|
||||||
|
markdown_content += f"<HR>ComfyUI: {version_tag} [Desktop]"
|
||||||
|
else:
|
||||||
|
markdown_content += f"<HR>ComfyUI: {core.comfy_ui_revision}[{comfy_ui_hash[:6]}]({core.comfy_ui_commit_datetime.date()})"
|
||||||
else:
|
else:
|
||||||
markdown_content += (f"<HR>ComfyUI: {version_tag}<BR>"
|
markdown_content += (f"<HR>ComfyUI: {version_tag}<BR>"
|
||||||
f" ({core.comfy_ui_commit_datetime.date()})")
|
f" ({core.comfy_ui_commit_datetime.date()})")
|
||||||
|
|||||||
@@ -21,6 +21,8 @@ import { CustomNodesManager } from "./custom-nodes-manager.js";
|
|||||||
import { ModelManager } from "./model-manager.js";
|
import { ModelManager } from "./model-manager.js";
|
||||||
import { SnapshotManager } from "./snapshot.js";
|
import { SnapshotManager } from "./snapshot.js";
|
||||||
|
|
||||||
|
let manager_version = await getVersion();
|
||||||
|
|
||||||
var docStyle = document.createElement('style');
|
var docStyle = document.createElement('style');
|
||||||
docStyle.innerHTML = `
|
docStyle.innerHTML = `
|
||||||
.comfy-toast {
|
.comfy-toast {
|
||||||
@@ -42,7 +44,7 @@ docStyle.innerHTML = `
|
|||||||
|
|
||||||
#cm-manager-dialog {
|
#cm-manager-dialog {
|
||||||
width: 1000px;
|
width: 1000px;
|
||||||
height: 450px;
|
height: 455px;
|
||||||
box-sizing: content-box;
|
box-sizing: content-box;
|
||||||
z-index: 1000;
|
z-index: 1000;
|
||||||
overflow-y: auto;
|
overflow-y: auto;
|
||||||
@@ -139,7 +141,7 @@ docStyle.innerHTML = `
|
|||||||
|
|
||||||
.cm-notice-board {
|
.cm-notice-board {
|
||||||
width: 290px;
|
width: 290px;
|
||||||
height: 210px;
|
height: 230px;
|
||||||
overflow: auto;
|
overflow: auto;
|
||||||
color: var(--input-text);
|
color: var(--input-text);
|
||||||
border: 1px solid var(--descrip-text);
|
border: 1px solid var(--descrip-text);
|
||||||
@@ -228,9 +230,10 @@ var switch_comfyui_button = null;
|
|||||||
var fetch_updates_button = null;
|
var fetch_updates_button = null;
|
||||||
var update_all_button = null;
|
var update_all_button = null;
|
||||||
var restart_stop_button = null;
|
var restart_stop_button = null;
|
||||||
|
var update_policy_combo = null;
|
||||||
|
|
||||||
let share_option = 'all';
|
let share_option = 'all';
|
||||||
var is_updating_all = false;
|
var is_updating = false;
|
||||||
|
|
||||||
|
|
||||||
// copied style from https://github.com/pythongosssss/ComfyUI-Custom-Scripts
|
// copied style from https://github.com/pythongosssss/ComfyUI-Custom-Scripts
|
||||||
@@ -477,6 +480,8 @@ async function updateComfyUI() {
|
|||||||
const response = await api.fetchApi('/manager/queue/update_comfyui');
|
const response = await api.fetchApi('/manager/queue/update_comfyui');
|
||||||
|
|
||||||
showTerminal();
|
showTerminal();
|
||||||
|
|
||||||
|
is_updating = true;
|
||||||
await api.fetchApi('/manager/queue/start');
|
await api.fetchApi('/manager/queue/start');
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -605,8 +610,14 @@ function showVersionSelectorDialog(versions, current, onSelect) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
async function switchComfyUI() {
|
async function switchComfyUI() {
|
||||||
|
switch_comfyui_button.disabled = true;
|
||||||
|
switch_comfyui_button.style.backgroundColor = "gray";
|
||||||
|
|
||||||
let res = await api.fetchApi(`/comfyui_manager/comfyui_versions`, { cache: "no-store" });
|
let res = await api.fetchApi(`/comfyui_manager/comfyui_versions`, { cache: "no-store" });
|
||||||
|
|
||||||
|
switch_comfyui_button.disabled = false;
|
||||||
|
switch_comfyui_button.style.backgroundColor = "";
|
||||||
|
|
||||||
if(res.status == 200) {
|
if(res.status == 200) {
|
||||||
let obj = await res.json();
|
let obj = await res.json();
|
||||||
|
|
||||||
@@ -619,6 +630,15 @@ async function switchComfyUI() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
showVersionSelectorDialog(versions, obj.current, async (selected_version) => {
|
showVersionSelectorDialog(versions, obj.current, async (selected_version) => {
|
||||||
|
if(selected_version == 'nightly') {
|
||||||
|
update_policy_combo.value = 'nightly-comfyui';
|
||||||
|
api.fetchApi('/manager/policy/update?value=nightly-comfyui');
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
update_policy_combo.value = 'stable-comfyui';
|
||||||
|
api.fetchApi('/manager/policy/update?value=stable-comfyui');
|
||||||
|
}
|
||||||
|
|
||||||
let response = await api.fetchApi(`/comfyui_manager/comfyui_switch_version?ver=${selected_version}`, { cache: "no-store" });
|
let response = await api.fetchApi(`/comfyui_manager/comfyui_switch_version?ver=${selected_version}`, { cache: "no-store" });
|
||||||
if (response.status == 200) {
|
if (response.status == 200) {
|
||||||
infoToast(`ComfyUI version is switched to ${selected_version}`);
|
infoToast(`ComfyUI version is switched to ${selected_version}`);
|
||||||
@@ -694,11 +714,11 @@ async function onQueueStatus(event) {
|
|||||||
else if(event.detail.status == 'done') {
|
else if(event.detail.status == 'done') {
|
||||||
reset_action_buttons();
|
reset_action_buttons();
|
||||||
|
|
||||||
if(!is_updating_all) {
|
if(!is_updating) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
is_updating_all = false;
|
is_updating = false;
|
||||||
|
|
||||||
let success_list = [];
|
let success_list = [];
|
||||||
let failed_list = [];
|
let failed_list = [];
|
||||||
@@ -721,19 +741,25 @@ async function onQueueStatus(event) {
|
|||||||
|
|
||||||
let msg = "";
|
let msg = "";
|
||||||
|
|
||||||
if(success_list.length == 0 && comfyui_state != 'success') {
|
if(success_list.length == 0 && !comfyui_state.startsWith('success')) {
|
||||||
if(failed_list.length == 0) {
|
if(failed_list.length == 0) {
|
||||||
msg += "All custom nodes are already up to date.";
|
msg += "You are already up to date.";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
msg = "To apply the updates, you need to <button class='cm-small-button' id='cm-reboot-button5'>RESTART</button> ComfyUI.<hr>";
|
msg = "To apply the updates, you need to <button class='cm-small-button' id='cm-reboot-button5'>RESTART</button> ComfyUI.<hr>";
|
||||||
|
|
||||||
if(comfyui_state == 'success') {
|
if(comfyui_state == 'success-nightly') {
|
||||||
msg += "ComfyUI is updated.<BR><BR>";
|
msg += "ComfyUI has been updated to latest nightly version.<BR><BR>";
|
||||||
|
infoToast("ComfyUI has been updated to the latest nightly version.");
|
||||||
|
}
|
||||||
|
else if(comfyui_state.startsWith('success-stable')) {
|
||||||
|
const ver = comfyui_state.split("-").pop();
|
||||||
|
msg += `ComfyUI has been updated to ${ver}.<BR><BR>`;
|
||||||
|
infoToast(`ComfyUI has been updated to ${ver}`);
|
||||||
}
|
}
|
||||||
else if(comfyui_state == 'skip') {
|
else if(comfyui_state == 'skip') {
|
||||||
msg += "ComfyUI is already up-to-date.<BR><BR>"
|
msg += "ComfyUI is already up to date.<BR><BR>"
|
||||||
}
|
}
|
||||||
else if(comfyui_state != null) {
|
else if(comfyui_state != null) {
|
||||||
msg += "Failed to update ComfyUI.<BR><BR>"
|
msg += "Failed to update ComfyUI.<BR><BR>"
|
||||||
@@ -811,7 +837,7 @@ async function updateAll(update_comfyui, manager_dialog) {
|
|||||||
customAlert('Another task is already in progress. Please stop the ongoing task first.');
|
customAlert('Another task is already in progress. Please stop the ongoing task first.');
|
||||||
}
|
}
|
||||||
else if(response.status == 200) {
|
else if(response.status == 200) {
|
||||||
is_updating_all = true;
|
is_updating = true;
|
||||||
await api.fetchApi('/manager/queue/start');
|
await api.fetchApi('/manager/queue/start');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -934,7 +960,19 @@ class ManagerMenuDialog extends ComfyDialog {
|
|||||||
}
|
}
|
||||||
}),
|
}),
|
||||||
|
|
||||||
|
$el("button.cm-button", {
|
||||||
|
type: "button",
|
||||||
|
textContent: "Custom Nodes In Workflow",
|
||||||
|
onclick:
|
||||||
|
() => {
|
||||||
|
if(!CustomNodesManager.instance) {
|
||||||
|
CustomNodesManager.instance = new CustomNodesManager(app, self);
|
||||||
|
}
|
||||||
|
CustomNodesManager.instance.show(CustomNodesManager.ShowMode.IN_WORKFLOW);
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
|
||||||
|
$el("br", {}, []),
|
||||||
$el("button.cm-button", {
|
$el("button.cm-button", {
|
||||||
type: "button",
|
type: "button",
|
||||||
textContent: "Model Manager",
|
textContent: "Model Manager",
|
||||||
@@ -963,7 +1001,7 @@ class ManagerMenuDialog extends ComfyDialog {
|
|||||||
update_all_button,
|
update_all_button,
|
||||||
update_comfyui_button,
|
update_comfyui_button,
|
||||||
switch_comfyui_button,
|
switch_comfyui_button,
|
||||||
fetch_updates_button,
|
// fetch_updates_button,
|
||||||
|
|
||||||
$el("br", {}, []),
|
$el("br", {}, []),
|
||||||
restart_stop_button,
|
restart_stop_button,
|
||||||
@@ -995,6 +1033,8 @@ class ManagerMenuDialog extends ComfyDialog {
|
|||||||
}
|
}
|
||||||
|
|
||||||
createControlsLeft() {
|
createControlsLeft() {
|
||||||
|
const isElectron = 'electronAPI' in window;
|
||||||
|
|
||||||
let self = this;
|
let self = this;
|
||||||
|
|
||||||
this.update_check_checkbox = $el("input",{type:'checkbox', id:"skip_update_check"},[])
|
this.update_check_checkbox = $el("input",{type:'checkbox', id:"skip_update_check"},[])
|
||||||
@@ -1073,25 +1113,6 @@ class ManagerMenuDialog extends ComfyDialog {
|
|||||||
share_combo.appendChild($el('option', { value: option[0], text: `Share: ${option[1]}` }, []));
|
share_combo.appendChild($el('option', { value: option[0], text: `Share: ${option[1]}` }, []));
|
||||||
}
|
}
|
||||||
|
|
||||||
// default ui state
|
|
||||||
let component_policy_combo = document.createElement("select");
|
|
||||||
component_policy_combo.setAttribute("title", "When loading the workflow, configure which version of the component to use.");
|
|
||||||
component_policy_combo.className = "cm-menu-combo";
|
|
||||||
component_policy_combo.appendChild($el('option', { value: 'workflow', text: 'Component: Use workflow version' }, []));
|
|
||||||
component_policy_combo.appendChild($el('option', { value: 'higher', text: 'Component: Use higher version' }, []));
|
|
||||||
component_policy_combo.appendChild($el('option', { value: 'mine', text: 'Component: Use my version' }, []));
|
|
||||||
api.fetchApi('/manager/component/policy')
|
|
||||||
.then(response => response.text())
|
|
||||||
.then(data => {
|
|
||||||
component_policy_combo.value = data;
|
|
||||||
set_component_policy(data);
|
|
||||||
});
|
|
||||||
|
|
||||||
component_policy_combo.addEventListener('change', function (event) {
|
|
||||||
api.fetchApi(`/manager/component/policy?value=${event.target.value}`);
|
|
||||||
set_component_policy(event.target.value);
|
|
||||||
});
|
|
||||||
|
|
||||||
api.fetchApi('/manager/share_option')
|
api.fetchApi('/manager/share_option')
|
||||||
.then(response => response.text())
|
.then(response => response.text())
|
||||||
.then(data => {
|
.then(data => {
|
||||||
@@ -1111,6 +1132,43 @@ class ManagerMenuDialog extends ComfyDialog {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
let component_policy_combo = document.createElement("select");
|
||||||
|
component_policy_combo.setAttribute("title", "When loading the workflow, configure which version of the component to use.");
|
||||||
|
component_policy_combo.className = "cm-menu-combo";
|
||||||
|
component_policy_combo.appendChild($el('option', { value: 'workflow', text: 'Component: Use workflow version' }, []));
|
||||||
|
component_policy_combo.appendChild($el('option', { value: 'higher', text: 'Component: Use higher version' }, []));
|
||||||
|
component_policy_combo.appendChild($el('option', { value: 'mine', text: 'Component: Use my version' }, []));
|
||||||
|
api.fetchApi('/manager/policy/component')
|
||||||
|
.then(response => response.text())
|
||||||
|
.then(data => {
|
||||||
|
component_policy_combo.value = data;
|
||||||
|
set_component_policy(data);
|
||||||
|
});
|
||||||
|
|
||||||
|
component_policy_combo.addEventListener('change', function (event) {
|
||||||
|
api.fetchApi(`/manager/policy/component?value=${event.target.value}`);
|
||||||
|
set_component_policy(event.target.value);
|
||||||
|
});
|
||||||
|
|
||||||
|
update_policy_combo = document.createElement("select");
|
||||||
|
|
||||||
|
if(isElectron)
|
||||||
|
update_policy_combo.style.display = 'none';
|
||||||
|
|
||||||
|
update_policy_combo.setAttribute("title", "Sets the policy to be applied when performing an update.");
|
||||||
|
update_policy_combo.className = "cm-menu-combo";
|
||||||
|
update_policy_combo.appendChild($el('option', { value: 'stable-comfyui', text: 'Update: ComfyUI Stable Version' }, []));
|
||||||
|
update_policy_combo.appendChild($el('option', { value: 'nightly-comfyui', text: 'Update: ComfyUI Nightly Version' }, []));
|
||||||
|
api.fetchApi('/manager/policy/update')
|
||||||
|
.then(response => response.text())
|
||||||
|
.then(data => {
|
||||||
|
update_policy_combo.value = data;
|
||||||
|
});
|
||||||
|
|
||||||
|
update_policy_combo.addEventListener('change', function (event) {
|
||||||
|
api.fetchApi(`/manager/policy/update?value=${event.target.value}`);
|
||||||
|
});
|
||||||
|
|
||||||
return [
|
return [
|
||||||
$el("div", {}, [this.update_check_checkbox, uc_checkbox_text]),
|
$el("div", {}, [this.update_check_checkbox, uc_checkbox_text]),
|
||||||
$el("br", {}, []),
|
$el("br", {}, []),
|
||||||
@@ -1119,6 +1177,7 @@ class ManagerMenuDialog extends ComfyDialog {
|
|||||||
preview_combo,
|
preview_combo,
|
||||||
share_combo,
|
share_combo,
|
||||||
component_policy_combo,
|
component_policy_combo,
|
||||||
|
update_policy_combo,
|
||||||
$el("br", {}, []),
|
$el("br", {}, []),
|
||||||
|
|
||||||
$el("br", {}, []),
|
$el("br", {}, []),
|
||||||
@@ -1145,11 +1204,6 @@ class ManagerMenuDialog extends ComfyDialog {
|
|||||||
install_pip(url, self);
|
install_pip(url, self);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}),
|
|
||||||
$el("button.cm-experimental-button", {
|
|
||||||
type: "button",
|
|
||||||
textContent: "Unload models",
|
|
||||||
onclick: () => { free_models(); }
|
|
||||||
})
|
})
|
||||||
]),
|
]),
|
||||||
];
|
];
|
||||||
@@ -1278,7 +1332,7 @@ class ManagerMenuDialog extends ComfyDialog {
|
|||||||
$el("div.comfy-modal-content",
|
$el("div.comfy-modal-content",
|
||||||
[
|
[
|
||||||
$el("tr.cm-title", {}, [
|
$el("tr.cm-title", {}, [
|
||||||
$el("font", {size:6, color:"white"}, [`ComfyUI Manager Menu`])]
|
$el("font", {size:6, color:"white"}, [`ComfyUI Manager ${manager_version}`])]
|
||||||
),
|
),
|
||||||
$el("br", {}, []),
|
$el("br", {}, []),
|
||||||
$el("div.cm-menu-container",
|
$el("div.cm-menu-container",
|
||||||
@@ -1420,13 +1474,12 @@ async function getVersion() {
|
|||||||
return await version.text();
|
return await version.text();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
app.registerExtension({
|
app.registerExtension({
|
||||||
name: "Comfy.ManagerMenu",
|
name: "Comfy.ManagerMenu",
|
||||||
|
|
||||||
aboutPageBadges: [
|
aboutPageBadges: [
|
||||||
{
|
{
|
||||||
label: `ComfyUI-Manager ${await getVersion()}`,
|
label: `ComfyUI-Manager ${manager_version}`,
|
||||||
url: 'https://github.com/ltdrdata/ComfyUI-Manager',
|
url: 'https://github.com/ltdrdata/ComfyUI-Manager',
|
||||||
icon: 'pi pi-th-large'
|
icon: 'pi pi-th-large'
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -709,7 +709,7 @@ app.handleFile = handleFile;
|
|||||||
|
|
||||||
let current_component_policy = 'workflow';
|
let current_component_policy = 'workflow';
|
||||||
try {
|
try {
|
||||||
api.fetchApi('/manager/component/policy')
|
api.fetchApi('/manager/policy/component')
|
||||||
.then(response => response.text())
|
.then(response => response.text())
|
||||||
.then(data => { current_component_policy = data; });
|
.then(data => { current_component_policy = data; });
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -363,6 +363,7 @@ const pageHtml = `
|
|||||||
<button class="cn-manager-restart">Restart</button>
|
<button class="cn-manager-restart">Restart</button>
|
||||||
<button class="cn-manager-stop">Stop</button>
|
<button class="cn-manager-stop">Stop</button>
|
||||||
<div class="cn-flex-auto"></div>
|
<div class="cn-flex-auto"></div>
|
||||||
|
<button class="cn-manager-used-in-workflow">Used In Workflow</button>
|
||||||
<button class="cn-manager-check-update">Check Update</button>
|
<button class="cn-manager-check-update">Check Update</button>
|
||||||
<button class="cn-manager-check-missing">Check Missing</button>
|
<button class="cn-manager-check-missing">Check Missing</button>
|
||||||
<button class="cn-manager-install-url">Install via Git URL</button>
|
<button class="cn-manager-install-url">Install via Git URL</button>
|
||||||
@@ -374,7 +375,8 @@ const ShowMode = {
|
|||||||
UPDATE: "Update",
|
UPDATE: "Update",
|
||||||
MISSING: "Missing",
|
MISSING: "Missing",
|
||||||
FAVORITES: "Favorites",
|
FAVORITES: "Favorites",
|
||||||
ALTERNATIVES: "Alternatives"
|
ALTERNATIVES: "Alternatives",
|
||||||
|
IN_WORKFLOW: "In Workflow",
|
||||||
};
|
};
|
||||||
|
|
||||||
export class CustomNodesManager {
|
export class CustomNodesManager {
|
||||||
@@ -586,6 +588,10 @@ export class CustomNodesManager {
|
|||||||
label: "Update",
|
label: "Update",
|
||||||
value: ShowMode.UPDATE,
|
value: ShowMode.UPDATE,
|
||||||
hasData: false
|
hasData: false
|
||||||
|
}, {
|
||||||
|
label: "In Workflow",
|
||||||
|
value: ShowMode.IN_WORKFLOW,
|
||||||
|
hasData: false
|
||||||
}, {
|
}, {
|
||||||
label: "Missing",
|
label: "Missing",
|
||||||
value: ShowMode.MISSING,
|
value: ShowMode.MISSING,
|
||||||
@@ -726,7 +732,7 @@ export class CustomNodesManager {
|
|||||||
const value = e.target.value
|
const value = e.target.value
|
||||||
this.filter = value;
|
this.filter = value;
|
||||||
const item = this.getFilterItem(value);
|
const item = this.getFilterItem(value);
|
||||||
if (item && !item.hasData) {
|
if (item && (!item.hasData)) {
|
||||||
this.loadData(value);
|
this.loadData(value);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -779,6 +785,14 @@ export class CustomNodesManager {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
".cn-manager-used-in-workflow": {
|
||||||
|
click: (e) => {
|
||||||
|
e.target.classList.add("cn-btn-loading");
|
||||||
|
this.setFilter(ShowMode.IN_WORKFLOW);
|
||||||
|
this.loadData(ShowMode.IN_WORKFLOW);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
".cn-manager-check-update": {
|
".cn-manager-check-update": {
|
||||||
click: (e) => {
|
click: (e) => {
|
||||||
e.target.classList.add("cn-btn-loading");
|
e.target.classList.add("cn-btn-loading");
|
||||||
@@ -1529,7 +1543,110 @@ export class CustomNodesManager {
|
|||||||
return extension_mappings;
|
return extension_mappings;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
getNodesInWorkflow() {
|
||||||
|
let usedGroupNodes = new Set();
|
||||||
|
let allUsedNodes = {};
|
||||||
|
|
||||||
|
for(let k in app.graph._nodes) {
|
||||||
|
let node = app.graph._nodes[k];
|
||||||
|
|
||||||
|
if(node.type.startsWith('workflow>')) {
|
||||||
|
usedGroupNodes.add(node.type.slice(9));
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
allUsedNodes[node.type] = node;
|
||||||
|
}
|
||||||
|
|
||||||
|
for(let k of usedGroupNodes) {
|
||||||
|
let subnodes = app.graph.extra.groupNodes[k]?.nodes;
|
||||||
|
|
||||||
|
if(subnodes) {
|
||||||
|
for(let k2 in subnodes) {
|
||||||
|
let node = subnodes[k2];
|
||||||
|
allUsedNodes[node.type] = node;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return allUsedNodes;
|
||||||
|
}
|
||||||
|
|
||||||
async getMissingNodes() {
|
async getMissingNodes() {
|
||||||
|
let unresolved_missing_nodes = new Set();
|
||||||
|
let hashMap = {};
|
||||||
|
let allUsedNodes = this.getNodesInWorkflow();
|
||||||
|
|
||||||
|
const registered_nodes = new Set();
|
||||||
|
for (let i in LiteGraph.registered_node_types) {
|
||||||
|
registered_nodes.add(LiteGraph.registered_node_types[i].type);
|
||||||
|
}
|
||||||
|
|
||||||
|
let unresolved_aux_ids = {};
|
||||||
|
let outdated_comfyui = false;
|
||||||
|
|
||||||
|
for(let k in allUsedNodes) {
|
||||||
|
let node = allUsedNodes[k];
|
||||||
|
|
||||||
|
if(!registered_nodes.has(node.type)) {
|
||||||
|
// missing node
|
||||||
|
if(node.properties.cnr_id) {
|
||||||
|
if(node.properties.cnr_id == 'comfy-core') {
|
||||||
|
outdated_comfyui = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
let item = this.custom_nodes[node.properties.cnr_id];
|
||||||
|
hashMap[item.hash] = true;
|
||||||
|
}
|
||||||
|
else if(node.properties.aux_id) {
|
||||||
|
unresolved_aux_ids[node.properties.aux_id] = node.type;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
unresolved_missing_nodes.add(node.type);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(outdated_comfyui) {
|
||||||
|
customAlert('ComfyUI is outdated, so some built-in nodes cannot be used.');
|
||||||
|
}
|
||||||
|
|
||||||
|
if(Object.keys(unresolved_aux_ids).length > 0) {
|
||||||
|
// building aux_id to nodepack map
|
||||||
|
let aux_id_to_pack = {};
|
||||||
|
for(let k in this.custom_nodes) {
|
||||||
|
let nodepack = this.custom_nodes[k];
|
||||||
|
let aux_id;
|
||||||
|
if(nodepack.repository?.startsWith('https://github.com')) {
|
||||||
|
aux_id = nodepack.repository.split('/').slice(-2).join('/');
|
||||||
|
aux_id_to_pack[aux_id] = nodepack;
|
||||||
|
}
|
||||||
|
else if(nodepack.repository) {
|
||||||
|
aux_id = nodepack.repository.split('/').slice(-1);
|
||||||
|
aux_id_to_pack[aux_id] = nodepack;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// resolving aux_id
|
||||||
|
for(let k in unresolved_aux_ids) {
|
||||||
|
let nodepack = aux_id_to_pack[k];
|
||||||
|
if(nodepack) {
|
||||||
|
hashMap[nodepack.hash] = true;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
unresolved_missing_nodes.add(unresolved_aux_ids[k]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(unresolved_missing_nodes.size > 0) {
|
||||||
|
await this.getMissingNodesLegacy(hashMap, unresolved_missing_nodes, registered_nodes);
|
||||||
|
}
|
||||||
|
|
||||||
|
return hashMap;
|
||||||
|
}
|
||||||
|
|
||||||
|
async getMissingNodesLegacy(hashMap, missing_nodes, registered_nodes) {
|
||||||
const mode = manager_instance.datasrc_combo.value;
|
const mode = manager_instance.datasrc_combo.value;
|
||||||
this.showStatus(`Loading missing nodes (${mode}) ...`);
|
this.showStatus(`Loading missing nodes (${mode}) ...`);
|
||||||
const res = await fetchData(`/customnode/getmappings?mode=${mode}`);
|
const res = await fetchData(`/customnode/getmappings?mode=${mode}`);
|
||||||
@@ -1568,23 +1685,8 @@ export class CustomNodesManager {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const registered_nodes = new Set();
|
let unresolved_missing_nodes = new Set();
|
||||||
for (let i in LiteGraph.registered_node_types) {
|
for (let node_type of missing_nodes) {
|
||||||
registered_nodes.add(LiteGraph.registered_node_types[i].type);
|
|
||||||
}
|
|
||||||
|
|
||||||
const missing_nodes = new Set();
|
|
||||||
const workflow = app.graph.serialize();
|
|
||||||
const group_nodes = workflow.extra && workflow.extra.groupNodes ? workflow.extra.groupNodes : [];
|
|
||||||
let nodes = workflow.nodes;
|
|
||||||
|
|
||||||
for (let i in group_nodes) {
|
|
||||||
let group_node = group_nodes[i];
|
|
||||||
nodes = nodes.concat(group_node.nodes);
|
|
||||||
}
|
|
||||||
|
|
||||||
for (let i in nodes) {
|
|
||||||
const node_type = nodes[i].type;
|
|
||||||
if(node_type.startsWith('workflow/') || node_type.startsWith('workflow>'))
|
if(node_type.startsWith('workflow/') || node_type.startsWith('workflow>'))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
@@ -1592,26 +1694,25 @@ export class CustomNodesManager {
|
|||||||
const packs = name_to_packs[node_type.trim()];
|
const packs = name_to_packs[node_type.trim()];
|
||||||
if(packs)
|
if(packs)
|
||||||
packs.forEach(url => {
|
packs.forEach(url => {
|
||||||
missing_nodes.add(url);
|
unresolved_missing_nodes.add(url);
|
||||||
});
|
});
|
||||||
else {
|
else {
|
||||||
for(let j in regex_to_pack) {
|
for(let j in regex_to_pack) {
|
||||||
if(regex_to_pack[j].regex.test(node_type)) {
|
if(regex_to_pack[j].regex.test(node_type)) {
|
||||||
missing_nodes.add(regex_to_pack[j].url);
|
unresolved_missing_nodes.add(regex_to_pack[j].url);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const hashMap = {};
|
|
||||||
for(let k in this.custom_nodes) {
|
for(let k in this.custom_nodes) {
|
||||||
let item = this.custom_nodes[k];
|
let item = this.custom_nodes[k];
|
||||||
|
|
||||||
if(missing_nodes.has(item.id)) {
|
if(unresolved_missing_nodes.has(item.id)) {
|
||||||
hashMap[item.hash] = true;
|
hashMap[item.hash] = true;
|
||||||
}
|
}
|
||||||
else if (item.files?.some(file => missing_nodes.has(file))) {
|
else if (item.files?.some(file => unresolved_missing_nodes.has(file))) {
|
||||||
hashMap[item.hash] = true;
|
hashMap[item.hash] = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -1630,6 +1731,41 @@ export class CustomNodesManager {
|
|||||||
return hashMap;
|
return hashMap;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async getNodepackInWorkflow() {
|
||||||
|
let allUsedNodes = this.getNodesInWorkflow();
|
||||||
|
|
||||||
|
// building aux_id to nodepack map
|
||||||
|
let aux_id_to_pack = {};
|
||||||
|
for(let k in this.custom_nodes) {
|
||||||
|
let nodepack = this.custom_nodes[k];
|
||||||
|
let aux_id;
|
||||||
|
if(nodepack.repository?.startsWith('https://github.com')) {
|
||||||
|
aux_id = nodepack.repository.split('/').slice(-2).join('/');
|
||||||
|
aux_id_to_pack[aux_id] = nodepack;
|
||||||
|
}
|
||||||
|
else if(nodepack.repository) {
|
||||||
|
aux_id = nodepack.repository.split('/').slice(-1);
|
||||||
|
aux_id_to_pack[aux_id] = nodepack;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const hashMap = {};
|
||||||
|
for(let k in allUsedNodes) {
|
||||||
|
var item;
|
||||||
|
if(allUsedNodes[k].properties.cnr_id) {
|
||||||
|
item = this.custom_nodes[allUsedNodes[k].properties.cnr_id];
|
||||||
|
}
|
||||||
|
else if(allUsedNodes[k].properties.aux_id) {
|
||||||
|
item = aux_id_to_pack[allUsedNodes[k].properties.aux_id];
|
||||||
|
}
|
||||||
|
|
||||||
|
if(item)
|
||||||
|
hashMap[item.hash] = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return hashMap;
|
||||||
|
}
|
||||||
|
|
||||||
async getAlternatives() {
|
async getAlternatives() {
|
||||||
const mode = manager_instance.datasrc_combo.value;
|
const mode = manager_instance.datasrc_combo.value;
|
||||||
this.showStatus(`Loading alternatives (${mode}) ...`);
|
this.showStatus(`Loading alternatives (${mode}) ...`);
|
||||||
@@ -1725,9 +1861,14 @@ export class CustomNodesManager {
|
|||||||
hashMap = await this.getAlternatives();
|
hashMap = await this.getAlternatives();
|
||||||
} else if(this.show_mode == ShowMode.FAVORITES) {
|
} else if(this.show_mode == ShowMode.FAVORITES) {
|
||||||
hashMap = await this.getFavorites();
|
hashMap = await this.getFavorites();
|
||||||
|
} else if(this.show_mode == ShowMode.IN_WORKFLOW) {
|
||||||
|
hashMap = await this.getNodepackInWorkflow();
|
||||||
}
|
}
|
||||||
filterItem.hashMap = hashMap;
|
filterItem.hashMap = hashMap;
|
||||||
filterItem.hasData = true;
|
|
||||||
|
if(this.show_mode != ShowMode.IN_WORKFLOW) {
|
||||||
|
filterItem.hasData = true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for(let k in node_packs) {
|
for(let k in node_packs) {
|
||||||
@@ -1779,7 +1920,6 @@ export class CustomNodesManager {
|
|||||||
case "disabled":
|
case "disabled":
|
||||||
filterTypes.add("installed");
|
filterTypes.add("installed");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "not-installed":
|
case "not-installed":
|
||||||
filterTypes.add("not-installed");
|
filterTypes.add("not-installed");
|
||||||
break;
|
break;
|
||||||
|
|||||||
@@ -3,12 +3,21 @@
|
|||||||
* - custom node pack version to all custom nodes used in the workflow
|
* - custom node pack version to all custom nodes used in the workflow
|
||||||
*
|
*
|
||||||
* Example metadata:
|
* Example metadata:
|
||||||
"extra": {
|
* "nodes": {
|
||||||
"node_versions": {
|
* "1": {
|
||||||
"comfy-core": "v0.3.8-4-g0b2eb7f",
|
* type: "CheckpointLoaderSimple",
|
||||||
"comfyui-easy-use": "1.2.5"
|
* ...
|
||||||
}
|
* properties: {
|
||||||
},
|
* cnr_id: "comfy-core",
|
||||||
|
* version: "0.3.8",
|
||||||
|
* },
|
||||||
|
* },
|
||||||
|
* }
|
||||||
|
*
|
||||||
|
* @typedef {Object} NodeInfo
|
||||||
|
* @property {string} ver - Version (git hash or semantic version)
|
||||||
|
* @property {string} cnr_id - ComfyRegistry node ID
|
||||||
|
* @property {boolean} enabled - Whether the node is enabled
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import { app } from "../../scripts/app.js";
|
import { app } from "../../scripts/app.js";
|
||||||
@@ -23,7 +32,7 @@ class WorkflowMetadataExtension {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the installed nodes info
|
* Get the installed nodes info
|
||||||
* @returns {Promise<Record<string, {ver: string, cnr_id: string, enabled: boolean}>>} The mapping from node name to its info.
|
* @returns {Promise<Record<string, NodeInfo>>} The mapping from node name to its info.
|
||||||
* ver can either be a git commit hash or a semantic version such as "1.0.0"
|
* ver can either be a git commit hash or a semantic version such as "1.0.0"
|
||||||
* cnr_id is the id of the node in the ComfyRegistry
|
* cnr_id is the id of the node in the ComfyRegistry
|
||||||
* enabled is true if the node is enabled, false if it is disabled
|
* enabled is true if the node is enabled, false if it is disabled
|
||||||
@@ -33,61 +42,42 @@ class WorkflowMetadataExtension {
|
|||||||
return await res.json();
|
return await res.json();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the node versions for the given graph
|
|
||||||
* @param {LGraph} graph The graph to get the node versions for
|
|
||||||
* @returns {Promise<Record<string, string>>} The mapping from node name to version
|
|
||||||
*/
|
|
||||||
getGraphNodeVersions(graph) {
|
|
||||||
const nodeVersions = {};
|
|
||||||
for (const node of graph.nodes) {
|
|
||||||
const nodeData = node.constructor.nodeData;
|
|
||||||
// Frontend only nodes don't have nodeData
|
|
||||||
if (!nodeData) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
const modules = nodeData.python_module.split(".");
|
|
||||||
|
|
||||||
if (modules[0] === "custom_nodes") {
|
|
||||||
const nodePackageName = modules[1];
|
|
||||||
const nodeInfo =
|
|
||||||
this.installedNodes[nodePackageName] ??
|
|
||||||
this.installedNodes[nodePackageName.toLowerCase()];
|
|
||||||
if (nodeInfo) {
|
|
||||||
nodeVersions[nodePackageName] = nodeInfo.ver;
|
|
||||||
}
|
|
||||||
} else if (["nodes", "comfy_extras"].includes(modules[0])) {
|
|
||||||
nodeVersions["comfy-core"] = this.comfyCoreVersion;
|
|
||||||
} else {
|
|
||||||
console.warn(`Unknown node source: ${nodeData.python_module}`);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return nodeVersions;
|
|
||||||
}
|
|
||||||
|
|
||||||
async init() {
|
async init() {
|
||||||
const extension = this;
|
|
||||||
this.installedNodes = await this.getInstalledNodes();
|
this.installedNodes = await this.getInstalledNodes();
|
||||||
this.comfyCoreVersion = (await api.getSystemStats()).system.comfyui_version;
|
this.comfyCoreVersion = (await api.getSystemStats()).system.comfyui_version;
|
||||||
|
}
|
||||||
|
|
||||||
// Attach metadata when app.graphToPrompt is called.
|
/**
|
||||||
const originalSerialize = LGraph.prototype.serialize;
|
* Called when any node is created
|
||||||
LGraph.prototype.serialize = function () {
|
* @param {LGraphNode} node The newly created node
|
||||||
const workflow = originalSerialize.apply(this, arguments);
|
*/
|
||||||
|
nodeCreated(node) {
|
||||||
|
try {
|
||||||
|
// nodeData doesn't exist if node is missing or node is frontend only node
|
||||||
|
if (!node?.constructor?.nodeData?.python_module) return;
|
||||||
|
|
||||||
// Add metadata to the workflow
|
const nodeProperties = (node.properties ??= {});
|
||||||
if (!workflow.extra) {
|
const modules = node.constructor.nodeData.python_module.split(".");
|
||||||
workflow.extra = {};
|
const moduleType = modules[0];
|
||||||
|
|
||||||
|
if (moduleType === "custom_nodes") {
|
||||||
|
const nodePackageName = modules[1];
|
||||||
|
const { cnr_id, aux_id, ver } =
|
||||||
|
this.installedNodes[nodePackageName] ??
|
||||||
|
this.installedNodes[nodePackageName.toLowerCase()] ??
|
||||||
|
{};
|
||||||
|
|
||||||
|
if (cnr_id === "comfy-core") return; // don't allow hijacking comfy-core name
|
||||||
|
if (cnr_id) nodeProperties.cnr_id = cnr_id;
|
||||||
|
else nodeProperties.aux_id = aux_id;
|
||||||
|
if (ver) nodeProperties.ver = ver;
|
||||||
|
} else if (["nodes", "comfy_extras"].includes(moduleType)) {
|
||||||
|
nodeProperties.cnr_id = "comfy-core";
|
||||||
|
nodeProperties.ver = this.comfyCoreVersion;
|
||||||
}
|
}
|
||||||
const graph = this;
|
} catch (e) {
|
||||||
try {
|
console.error(e);
|
||||||
workflow.extra["node_versions"] = extension.getGraphNodeVersions(graph);
|
}
|
||||||
} catch (e) {
|
|
||||||
console.error(e);
|
|
||||||
}
|
|
||||||
|
|
||||||
return workflow;
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -4685,6 +4685,28 @@
|
|||||||
"filename": "<huggingface>",
|
"filename": "<huggingface>",
|
||||||
"url": "deepseek-ai/Janus-Pro-7B",
|
"url": "deepseek-ai/Janus-Pro-7B",
|
||||||
"size": "14.85GB"
|
"size": "14.85GB"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "kolors/vae/diffusion_pytorch_model.fp16.safetensors",
|
||||||
|
"type": "VAE",
|
||||||
|
"base": "Kolors",
|
||||||
|
"save_path": "vae/kolors",
|
||||||
|
"description": "Kolors VAE",
|
||||||
|
"reference": "https://huggingface.co/Kwai-Kolors/Kolors",
|
||||||
|
"filename": "diffusion_pytorch_model.fp16.safetensors",
|
||||||
|
"url": "https://huggingface.co/Kwai-Kolors/Kolors/resolve/main/vae/diffusion_pytorch_model.fp16.safetensors",
|
||||||
|
"size": "167MB"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "kolors/vae/diffusion_pytorch_model.safetensors",
|
||||||
|
"type": "VAE",
|
||||||
|
"base": "Kolors",
|
||||||
|
"save_path": "vae/kolors",
|
||||||
|
"description": "Kolors VAE",
|
||||||
|
"reference": "https://huggingface.co/Kwai-Kolors/Kolors",
|
||||||
|
"filename": "diffusion_pytorch_model.safetensors",
|
||||||
|
"url": "https://huggingface.co/Kwai-Kolors/Kolors/resolve/main/vae/diffusion_pytorch_model.safetensors",
|
||||||
|
"size": "335MB"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -13,6 +13,198 @@
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
{
|
||||||
|
"author": "IfnotFr",
|
||||||
|
"title": "⚡ ComfyUI Connect [WIP]",
|
||||||
|
"reference": "https://github.com/IfnotFr/ComfyUI-Connect",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/IfnotFr/ComfyUI-Connect"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Transform your ComfyUI into a powerful API, exposing all your saved workflows as ready-to-use HTTP endpoints."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "muvich3n",
|
||||||
|
"title": "ComfyUI-Crop-Border",
|
||||||
|
"reference": "https://github.com/muvich3n/ComfyUI-Crop-Border",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/muvich3n/ComfyUI-Crop-Border"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "NODES: Crop Image Borders"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "masmullin2000",
|
||||||
|
"title": "ComfyUI-MMYolo",
|
||||||
|
"reference": "https://github.com/masmullin2000/ComfyUI-MMYolo",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/masmullin2000/ComfyUI-MMYolo"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A comfy node to find faces and output a mask"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "RiceRound",
|
||||||
|
"title": "RiceRound Cloud Node [UNSAFE]",
|
||||||
|
"id": "riceround",
|
||||||
|
"reference": "https://github.com/RiceRound/ComfyUI_RiceRound",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/RiceRound/ComfyUI_RiceRound"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "This is an imaginative project that allows for one-click deployment, providing both an online page and a ComfyUI cloud node.[w/This custom node is vulnerable because it can dynamically download and execute nodes.]"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "Yeonri",
|
||||||
|
"title": "ComfyUI_LLM_Are_You_Listening [WIP]",
|
||||||
|
"reference": "https://github.com/Yeonri/ComfyUI_LLM_Are_You_Listening",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/Yeonri/ComfyUI_LLM_Are_You_Listening"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "NODES: AYL_Node, AYL_GGUF_Node, AYL_API_Node\nNOTE: The files in the repo are not organized."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "altkeyproject",
|
||||||
|
"title": "Dream Painter [WIP]",
|
||||||
|
"reference": "https://github.com/alt-key-project/comfyui-dream-painter",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/alt-key-project/comfyui-dream-painter"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Provide utilities for 2D image generation and processing."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "kimara-ai",
|
||||||
|
"title": "ComfyUI-Kimara-AI-Image-From-URL [WIP]",
|
||||||
|
"reference": "https://github.com/kimara-ai/ComfyUI-Kimara-AI-Image-From-URL",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/kimara-ai/ComfyUI-Kimara-AI-Image-From-URL"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Load image from URL and downscale to desired megapixels. Set megapixels to 0 for no downscaling."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "krisshen2021",
|
||||||
|
"title": "comfyui_OpenRouterNodes [WIP]",
|
||||||
|
"reference": "https://github.com/krisshen2021/comfyui_OpenRouterNodes",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/krisshen2021/comfyui_OpenRouterNodes"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "LLM custom nodes for comfyui\nNOTE: The files in the repo are not organized."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "Velour-Fog",
|
||||||
|
"title": "comfy-latent-nodes [UNSAFE]",
|
||||||
|
"reference": "https://github.com/Velour-Fog/comfy-latent-nodes",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/Velour-Fog/comfy-latent-nodes"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "ComfyUI nodes to save and load a latent to a specified directory. Saves time for doing operations on a latent such as upscaling without having to re-trigger the creation of the original latent.[w/This node can write files to an arbitrary path.]"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "jgbyte",
|
||||||
|
"title": "ComfyUI-RandomCube [WIP]",
|
||||||
|
"reference": "https://github.com/jgbyte/ComfyUI-RandomCube",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/jgbyte/ComfyUI-RandomCube"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "NODES: RandomCubeGrid"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "thot-experiment",
|
||||||
|
"title": "comfy-live-preview [WIP]",
|
||||||
|
"reference": "https://github.com/thot-experiment/comfy-live-preview",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/thot-experiment/comfy-live-preview"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "external live preview plugin for ComfyUI"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "AhBumm",
|
||||||
|
"title": "ComfyUI-Upscayl",
|
||||||
|
"reference": "https://github.com/AhBumm/ComfyUI-Upscayl",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/AhBumm/ComfyUI-Upscayl"
|
||||||
|
],
|
||||||
|
"nodename_pattern": "\\(BillBum\\)$",
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "NODES: Upscayl Upscaler"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "NEZHA625",
|
||||||
|
"title": "ComfyUI-tools-by-dong [UNSAFE]",
|
||||||
|
"reference": "https://github.com/NEZHA625/ComfyUI-tools-by-dong",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/NEZHA625/ComfyUI-tools-by-dong"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "NODES: HuggingFaceUploadNode, ImageDownloader, LoraIterator, FileMoveNode, InputDetectionNode, ...\nNOTE: The files in the repo are not organized.[w/This node pack includes nodes that can modify arbitrary files.]"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "if-ai",
|
||||||
|
"title": "ComfyUI-IF_Zonos [WIP]",
|
||||||
|
"reference": "https://github.com/if-ai/ComfyUI-IF_Zonos",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/if-ai/ComfyUI-IF_Zonos"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Zonos for ComfyUI"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "grinlau18",
|
||||||
|
"title": "Xiser_Nodes [WIP]",
|
||||||
|
"reference": "https://github.com/grinlau18/ComfyUI_XISER_Nodes",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/grinlau18/ComfyUI_XISER_Nodes"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A collection of custom nodes for ComfyUI\nNOTE: The files in the repo are not organized."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "LAOGOU-666",
|
||||||
|
"title": "Comfyui_StartPatch [UNSAFE]",
|
||||||
|
"reference": "https://github.com/LAOGOU-666/Comfyui_StartPatch",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/LAOGOU-666/Comfyui_StartPatch"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "This patch plugin optimizes the node information processing mechanism of the ComfyUI server, significantly improving server performance and response speed. It greatly reduces the browser page initialization waiting time. [w/Since this patch modifies key functions of ComfyUI, it is highly likely to cause compatibility issues.]"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "badmike",
|
||||||
|
"title": "Prompt Factory [CONFLICT]",
|
||||||
|
"reference": "https://github.com/badmike/comfyui-prompt-factory",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/badmike/comfyui-prompt-factory"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A modular system that adds randomness to prompt generation [w/This node pack is causing a name conflict with https://github.com/satche/comfyui-prompt-factory]"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "owengillett",
|
||||||
|
"title": "ComfyUI-tilefusion",
|
||||||
|
"reference": "https://github.com/owengillett/ComfyUI-tilefusion",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/owengillett/ComfyUI-tilefusion"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Helper nodes for generating seamless tiles."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "Scaryplasmon",
|
||||||
|
"title": "ComfTrellis [WIP]",
|
||||||
|
"reference": "https://github.com/Scaryplasmon/ComfTrellis",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/Scaryplasmon/ComfTrellis"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "1 click install to run Trellis in ComfyUI\nNOTE: The files in the repo are not organized."
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"author": "fangziheng2321",
|
"author": "fangziheng2321",
|
||||||
"title": "comfyuinode_chopmask [WIP]",
|
"title": "comfyuinode_chopmask [WIP]",
|
||||||
@@ -23,16 +215,6 @@
|
|||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "a custom comfyui node for '/fooocusinpaint_upload'\nNOTE: The files in the repo are not organized."
|
"description": "a custom comfyui node for '/fooocusinpaint_upload'\nNOTE: The files in the repo are not organized."
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"author": "RodrigoSKohl",
|
|
||||||
"title": "Interior Design for Comfyui [WIP]",
|
|
||||||
"reference": "https://github.com/RodrigoSKohl/StableDesign-for-ComfyUI",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/RodrigoSKohl/StableDesign-for-ComfyUI"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "This node is based on MykolaL/StableDesign"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"author": "D1-3105",
|
"author": "D1-3105",
|
||||||
"title": "ComfyUI-VideoStream",
|
"title": "ComfyUI-VideoStream",
|
||||||
@@ -83,16 +265,6 @@
|
|||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "This is a custom plugin node for ComfyUI that modifies and extends some features from existing projects. The main implementations include:\n* Reproducing some features of the [a/Stable-Diffusion-Webui-Civitai-Helper](https://github.com/zixaphir/Stable-Diffusion-Webui-Civitai-Helper) project within ComfyUI\n* Implementing a feature to randomly generate related prompt words by referencing the [a/noob-wiki dataset](https://huggingface.co/datasets/Laxhar/noob-wiki/tree/main)\nNOTE: The files in the repo are not organized."
|
"description": "This is a custom plugin node for ComfyUI that modifies and extends some features from existing projects. The main implementations include:\n* Reproducing some features of the [a/Stable-Diffusion-Webui-Civitai-Helper](https://github.com/zixaphir/Stable-Diffusion-Webui-Civitai-Helper) project within ComfyUI\n* Implementing a feature to randomly generate related prompt words by referencing the [a/noob-wiki dataset](https://huggingface.co/datasets/Laxhar/noob-wiki/tree/main)\nNOTE: The files in the repo are not organized."
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"author": "dasilva333",
|
|
||||||
"title": "ComfyUI_MarkdownImage [WIP]",
|
|
||||||
"reference": "https://github.com/dasilva333/ComfyUI_MarkdownImage",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/dasilva333/ComfyUI_MarkdownImage"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "Create an image using html and markdown in ComfyUI\nNOTE: The files in the repo are not organized."
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"author": "franky519",
|
"author": "franky519",
|
||||||
"title": "comfyui-redux-style",
|
"title": "comfyui-redux-style",
|
||||||
@@ -143,16 +315,6 @@
|
|||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "NODES: Load TIFF"
|
"description": "NODES: Load TIFF"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"author": "greengerong",
|
|
||||||
"title": "ComfyUI-Lumina-Video [WIP]",
|
|
||||||
"reference": "https://github.com/greengerong/ComfyUI-Lumina-Video",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/greengerong/ComfyUI-Lumina-Video"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "This is a video generation plugin implementation for ComfyUI based on the Lumina Video model."
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"author": "tc888",
|
"author": "tc888",
|
||||||
"title": "ComfyUI_Save_Flux_Image",
|
"title": "ComfyUI_Save_Flux_Image",
|
||||||
@@ -782,7 +944,7 @@
|
|||||||
"https://github.com/yanhuifair/ComfyUI-FairLab"
|
"https://github.com/yanhuifair/ComfyUI-FairLab"
|
||||||
],
|
],
|
||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "NODES: CLIP Text Encode Translated, Translate String, Load Image From Folder, Save String To Folder, Fix UTF-8 String, String Combine, String Field, Download Image, Save Images To Folder, Save Image To Folder, Image Resize"
|
"description": "NODES: CLIP Text Encode Translated, Translate String, Load Image From Folder, Save String To Folder, Fix UTF-8 String, String Combine, String Field, Download Image, Save Images To Folder, Save Image To Folder, Image Resize, ..."
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"author": "nomcycle",
|
"author": "nomcycle",
|
||||||
@@ -1681,16 +1843,6 @@
|
|||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "To use stepfun's library, you need an official api that supports multimodal inputs such as video and pictures [a/https://platform.stepfun.com/request-restriction](https://platform.stepfun.com/request-restriction)"
|
"description": "To use stepfun's library, you need an official api that supports multimodal inputs such as video and pictures [a/https://platform.stepfun.com/request-restriction](https://platform.stepfun.com/request-restriction)"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"author": "attashe",
|
|
||||||
"title": "ComfyUI-FluxRegionAttention [WIP]",
|
|
||||||
"reference": "https://github.com/attashe/ComfyUI-FluxRegionAttention",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/attashe/ComfyUI-FluxRegionAttention"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "Implement Region Attention for Flux model"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"author": "aria1th",
|
"author": "aria1th",
|
||||||
"title": "ComfyUI-SkipCFGSigmas",
|
"title": "ComfyUI-SkipCFGSigmas",
|
||||||
|
|||||||
@@ -370,6 +370,15 @@
|
|||||||
"title_aux": "comfyui-textools [WIP]"
|
"title_aux": "comfyui-textools [WIP]"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/AhBumm/ComfyUI-Upscayl": [
|
||||||
|
[
|
||||||
|
"Upscayl Upscaler"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"nodename_pattern": "\\(BillBum\\)$",
|
||||||
|
"title_aux": "ComfyUI-Upscayl"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/AlexXi19/ComfyUI-OpenAINode": [
|
"https://github.com/AlexXi19/ComfyUI-OpenAINode": [
|
||||||
[
|
[
|
||||||
"ImageWithPrompt",
|
"ImageWithPrompt",
|
||||||
@@ -741,7 +750,6 @@
|
|||||||
"https://github.com/DraconicDragon/ComfyUI_e621_booru_toolkit": [
|
"https://github.com/DraconicDragon/ComfyUI_e621_booru_toolkit": [
|
||||||
[
|
[
|
||||||
"GetBooruPost",
|
"GetBooruPost",
|
||||||
"TagEncode",
|
|
||||||
"TagWikiFetch"
|
"TagWikiFetch"
|
||||||
],
|
],
|
||||||
{
|
{
|
||||||
@@ -1021,6 +1029,7 @@
|
|||||||
"ImNodeTitleOverride",
|
"ImNodeTitleOverride",
|
||||||
"ImSetActionKeywordMapping",
|
"ImSetActionKeywordMapping",
|
||||||
"MergeNode",
|
"MergeNode",
|
||||||
|
"Molmo7BDbnbBatch",
|
||||||
"MuteNode",
|
"MuteNode",
|
||||||
"NewNode",
|
"NewNode",
|
||||||
"Node2String",
|
"Node2String",
|
||||||
@@ -1326,6 +1335,38 @@
|
|||||||
"title_aux": "ComfyUI-APG_ImYourCFGNow"
|
"title_aux": "ComfyUI-APG_ImYourCFGNow"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/NEZHA625/ComfyUI-tools-by-dong": [
|
||||||
|
[
|
||||||
|
"A1111_FLUX_DATA_NODE",
|
||||||
|
"CategorizeNode",
|
||||||
|
"FileMoveNode",
|
||||||
|
"FolderIteratorNODE",
|
||||||
|
"Get_cookies_Node",
|
||||||
|
"Get_json_value_Node",
|
||||||
|
"HashCalculationsNode",
|
||||||
|
"HuggingFaceUploadNode",
|
||||||
|
"Image2GIFNode",
|
||||||
|
"ImageDownloader",
|
||||||
|
"InputDetectionNode",
|
||||||
|
"LLM_Node",
|
||||||
|
"LibLib_upload_Node",
|
||||||
|
"LogicToolsNode",
|
||||||
|
"LoraIterator",
|
||||||
|
"RandomNumbersNode",
|
||||||
|
"RenameNode",
|
||||||
|
"ResolutionNode",
|
||||||
|
"SaveTXTNode",
|
||||||
|
"SetAppidNode",
|
||||||
|
"TextToJsonNode",
|
||||||
|
"TranslateAPINode",
|
||||||
|
"ZIPwith7zNode",
|
||||||
|
"path_join_Node",
|
||||||
|
"set_api_Node"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "ComfyUI-tools-by-dong [UNSAFE]"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/Northerner1/ComfyUI_North_Noise": [
|
"https://github.com/Northerner1/ComfyUI_North_Noise": [
|
||||||
[
|
[
|
||||||
"North_Unsampler"
|
"North_Unsampler"
|
||||||
@@ -1425,6 +1466,41 @@
|
|||||||
"title_aux": "comfyui-promptbymood [WIP]"
|
"title_aux": "comfyui-promptbymood [WIP]"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/RiceRound/ComfyUI_RiceRound": [
|
||||||
|
[
|
||||||
|
"RiceRoundAdvancedChoiceNode",
|
||||||
|
"RiceRoundBooleanNode",
|
||||||
|
"RiceRoundDecryptNode",
|
||||||
|
"RiceRoundDownloadImageAndMaskNode",
|
||||||
|
"RiceRoundDownloadImageNode",
|
||||||
|
"RiceRoundDownloadMaskNode",
|
||||||
|
"RiceRoundEncryptNode",
|
||||||
|
"RiceRoundFloatNode",
|
||||||
|
"RiceRoundImageBridgeNode",
|
||||||
|
"RiceRoundImageNode",
|
||||||
|
"RiceRoundImageUrlNode",
|
||||||
|
"RiceRoundInputTextNode",
|
||||||
|
"RiceRoundIntNode",
|
||||||
|
"RiceRoundMaskBridgeNode",
|
||||||
|
"RiceRoundOutputBooleanNode",
|
||||||
|
"RiceRoundOutputFloatNode",
|
||||||
|
"RiceRoundOutputImageBridgeNode",
|
||||||
|
"RiceRoundOutputImageNode",
|
||||||
|
"RiceRoundOutputIntNode",
|
||||||
|
"RiceRoundOutputMaskBridgeNode",
|
||||||
|
"RiceRoundOutputTextNode",
|
||||||
|
"RiceRoundRandomSeedNode",
|
||||||
|
"RiceRoundSimpleChoiceNode",
|
||||||
|
"RiceRoundSimpleImageNode",
|
||||||
|
"RiceRoundStrToBooleanNode",
|
||||||
|
"RiceRoundStrToFloatNode",
|
||||||
|
"RiceRoundStrToIntNode",
|
||||||
|
"RiceRoundUploadImageNode"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "RiceRound Cloud Node [UNSAFE]"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/RicherdLee/comfyui-oss-image-save": [
|
"https://github.com/RicherdLee/comfyui-oss-image-save": [
|
||||||
[
|
[
|
||||||
"SaveImageOSS"
|
"SaveImageOSS"
|
||||||
@@ -1435,6 +1511,8 @@
|
|||||||
],
|
],
|
||||||
"https://github.com/RobeSantoro/ComfyUI-RobeNodes": [
|
"https://github.com/RobeSantoro/ComfyUI-RobeNodes": [
|
||||||
[
|
[
|
||||||
|
"Boolean Primitive \ud83d\udc24",
|
||||||
|
"Image Input Switch \ud83d\udc24",
|
||||||
"List Image Path \ud83d\udc24",
|
"List Image Path \ud83d\udc24",
|
||||||
"List Model Path \ud83d\udc24",
|
"List Model Path \ud83d\udc24",
|
||||||
"List Video Path \ud83d\udc24",
|
"List Video Path \ud83d\udc24",
|
||||||
@@ -1444,14 +1522,6 @@
|
|||||||
"title_aux": "Comfy UI Robe Nodes [UNSAFE]"
|
"title_aux": "Comfy UI Robe Nodes [UNSAFE]"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"https://github.com/RodrigoSKohl/StableDesign-for-ComfyUI": [
|
|
||||||
[
|
|
||||||
"interior-design-for-comfyui"
|
|
||||||
],
|
|
||||||
{
|
|
||||||
"title_aux": "Interior Design for Comfyui [WIP]"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"https://github.com/SS-snap/ComfyUI-Snap_Processing": [
|
"https://github.com/SS-snap/ComfyUI-Snap_Processing": [
|
||||||
[
|
[
|
||||||
"AreaCalculator",
|
"AreaCalculator",
|
||||||
@@ -1496,6 +1566,18 @@
|
|||||||
"title_aux": "ComfyUI_Save2Discord"
|
"title_aux": "ComfyUI_Save2Discord"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/Scaryplasmon/ComfTrellis": [
|
||||||
|
[
|
||||||
|
"LoadTrellisModel",
|
||||||
|
"RembgSquare",
|
||||||
|
"SaveGLBFile",
|
||||||
|
"TrellisGrid",
|
||||||
|
"TrellisInference"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "ComfTrellis [WIP]"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/SeedV/ComfyUI-SeedV-Nodes": [
|
"https://github.com/SeedV/ComfyUI-SeedV-Nodes": [
|
||||||
[
|
[
|
||||||
"ALL_Model_UnLoader(SEEDV)",
|
"ALL_Model_UnLoader(SEEDV)",
|
||||||
@@ -1703,6 +1785,15 @@
|
|||||||
"title_aux": "plugin-utils-nodes"
|
"title_aux": "plugin-utils-nodes"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/Velour-Fog/comfy-latent-nodes": [
|
||||||
|
[
|
||||||
|
"CustomLoadLatent",
|
||||||
|
"CustomSaveLatent"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "comfy-latent-nodes [UNSAFE]"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/Video3DGenResearch/comfyui-batch-input-node": [
|
"https://github.com/Video3DGenResearch/comfyui-batch-input-node": [
|
||||||
[
|
[
|
||||||
"BatchImageAndPrompt",
|
"BatchImageAndPrompt",
|
||||||
@@ -1756,6 +1847,16 @@
|
|||||||
"title_aux": "visuallabs_comfyui_nodes"
|
"title_aux": "visuallabs_comfyui_nodes"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/Yeonri/ComfyUI_LLM_Are_You_Listening": [
|
||||||
|
[
|
||||||
|
"AYL_API_Node",
|
||||||
|
"AYL_GGUF_Node",
|
||||||
|
"AYL_Node"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "ComfyUI_LLM_Are_You_Listening [WIP]"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/ZHO-ZHO-ZHO/ComfyUI-AuraSR-ZHO": [
|
"https://github.com/ZHO-ZHO-ZHO/ComfyUI-AuraSR-ZHO": [
|
||||||
[
|
[
|
||||||
"AuraSR_Lterative_Zho",
|
"AuraSR_Lterative_Zho",
|
||||||
@@ -1861,6 +1962,39 @@
|
|||||||
"title_aux": "alexisrolland/ComfyUI-AuraSR"
|
"title_aux": "alexisrolland/ComfyUI-AuraSR"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/alt-key-project/comfyui-dream-painter": [
|
||||||
|
[
|
||||||
|
"Bitmap AND [DPaint]",
|
||||||
|
"Bitmap Crop Center [DPaint]",
|
||||||
|
"Bitmap Dimensions [DPaint]",
|
||||||
|
"Bitmap Edge Detect [DPaint]",
|
||||||
|
"Bitmap Expand Canvas [DPaint]",
|
||||||
|
"Bitmap Invert [DPaint]",
|
||||||
|
"Bitmap OR [DPaint]",
|
||||||
|
"Bitmap Resize [DPaint]",
|
||||||
|
"Bitmap Rotate [DPaint]",
|
||||||
|
"Bitmap To Image & Mask [DPaint]",
|
||||||
|
"Bitmap XOR [DPaint]",
|
||||||
|
"Draw Shape As Bitmap [DPaint]",
|
||||||
|
"Image To Bitmap [DPaint]",
|
||||||
|
"Random Number Generator [DPaint]",
|
||||||
|
"Shape Center & Fit [DPaint]",
|
||||||
|
"Shape Combiner [DPaint]",
|
||||||
|
"Shape Copycat Tool [DPaint]",
|
||||||
|
"Shape Find Bounds [DPaint]",
|
||||||
|
"Shape Flip [DPaint]",
|
||||||
|
"Shape Grid [DPaint]",
|
||||||
|
"Shape Resize [DPaint]",
|
||||||
|
"Shape Rotate [DPaint]",
|
||||||
|
"Shape of Circular Rays [DPaint]",
|
||||||
|
"Shape of N-Polygon [DPaint]",
|
||||||
|
"Shape of Rectangle [DPaint]",
|
||||||
|
"Shape of Star [DPaint]"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "Dream Painter [WIP]"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/alt-key-project/comfyui-dream-video-batches": [
|
"https://github.com/alt-key-project/comfyui-dream-video-batches": [
|
||||||
[
|
[
|
||||||
"Blended Transition [DVB]",
|
"Blended Transition [DVB]",
|
||||||
@@ -1953,20 +2087,6 @@
|
|||||||
"title_aux": "comfyui_segformer_b2_sleeves"
|
"title_aux": "comfyui_segformer_b2_sleeves"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"https://github.com/attashe/ComfyUI-FluxRegionAttention": [
|
|
||||||
[
|
|
||||||
"BBoxToMaskNode",
|
|
||||||
"BoundingBoxNode",
|
|
||||||
"CLIPDebug",
|
|
||||||
"FluxRegionBBOX",
|
|
||||||
"FluxRegionMask",
|
|
||||||
"RegionAttention",
|
|
||||||
"VisualizeBBoxesNode"
|
|
||||||
],
|
|
||||||
{
|
|
||||||
"title_aux": "ComfyUI-FluxRegionAttention [WIP]"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"https://github.com/backearth1/Comfyui-MiniMax-Video": [
|
"https://github.com/backearth1/Comfyui-MiniMax-Video": [
|
||||||
[
|
[
|
||||||
"ImageToPrompt",
|
"ImageToPrompt",
|
||||||
@@ -2476,6 +2596,7 @@
|
|||||||
"LoadAudio",
|
"LoadAudio",
|
||||||
"LoadImage",
|
"LoadImage",
|
||||||
"LoadImageMask",
|
"LoadImageMask",
|
||||||
|
"LoadImageOutput",
|
||||||
"LoadLatent",
|
"LoadLatent",
|
||||||
"LoraLoader",
|
"LoraLoader",
|
||||||
"LoraLoaderModelOnly",
|
"LoraLoaderModelOnly",
|
||||||
@@ -2550,6 +2671,7 @@
|
|||||||
"SaveImage",
|
"SaveImage",
|
||||||
"SaveImageWebsocket",
|
"SaveImageWebsocket",
|
||||||
"SaveLatent",
|
"SaveLatent",
|
||||||
|
"SaveWEBM",
|
||||||
"SelfAttentionGuidance",
|
"SelfAttentionGuidance",
|
||||||
"SetFirstSigma",
|
"SetFirstSigma",
|
||||||
"SetLatentNoiseMask",
|
"SetLatentNoiseMask",
|
||||||
@@ -2692,15 +2814,6 @@
|
|||||||
"title_aux": "VoidCustomNodes"
|
"title_aux": "VoidCustomNodes"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"https://github.com/dasilva333/ComfyUI_MarkdownImage": [
|
|
||||||
[
|
|
||||||
"CreateDialogImage",
|
|
||||||
"CreateMarkdownImage"
|
|
||||||
],
|
|
||||||
{
|
|
||||||
"title_aux": "ComfyUI_MarkdownImage [WIP]"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"https://github.com/denislov/Comfyui_AutoSurvey": [
|
"https://github.com/denislov/Comfyui_AutoSurvey": [
|
||||||
[
|
[
|
||||||
"AddDoc2Knowledge",
|
"AddDoc2Knowledge",
|
||||||
@@ -3004,7 +3117,9 @@
|
|||||||
],
|
],
|
||||||
"https://github.com/gmorks/ComfyUI-Animagine-Prompt": [
|
"https://github.com/gmorks/ComfyUI-Animagine-Prompt": [
|
||||||
[
|
[
|
||||||
"AnimaginePrompt"
|
"AnimaginePrompt",
|
||||||
|
"MultilineTextInput",
|
||||||
|
"TextFileLoader"
|
||||||
],
|
],
|
||||||
{
|
{
|
||||||
"title_aux": "ComfyUI Animagine prompt [WIP]"
|
"title_aux": "ComfyUI Animagine prompt [WIP]"
|
||||||
@@ -3036,16 +3151,6 @@
|
|||||||
"title_aux": "loki-comfyui-node"
|
"title_aux": "loki-comfyui-node"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"https://github.com/greengerong/ComfyUI-Lumina-Video": [
|
|
||||||
[
|
|
||||||
"LuminaVideoModelLoader",
|
|
||||||
"LuminaVideoSampler",
|
|
||||||
"LuminaVideoVAEDecode"
|
|
||||||
],
|
|
||||||
{
|
|
||||||
"title_aux": "ComfyUI-Lumina-Video [WIP]"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"https://github.com/grimli333/ComfyUI_Grim": [
|
"https://github.com/grimli333/ComfyUI_Grim": [
|
||||||
[
|
[
|
||||||
"GenerateFileName",
|
"GenerateFileName",
|
||||||
@@ -3055,6 +3160,17 @@
|
|||||||
"title_aux": "ComfyUI_Grim"
|
"title_aux": "ComfyUI_Grim"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/grinlau18/ComfyUI_XISER_Nodes": [
|
||||||
|
[
|
||||||
|
"XIS_Float_Slider",
|
||||||
|
"XIS_INT_Slider",
|
||||||
|
"XIS_PromptsWithSwitches",
|
||||||
|
"XIS_ResizeImageOrMask"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "Xiser_Nodes [WIP]"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/haodman/ComfyUI_Rain": [
|
"https://github.com/haodman/ComfyUI_Rain": [
|
||||||
[
|
[
|
||||||
"Rain_ImageSize",
|
"Rain_ImageSize",
|
||||||
@@ -3093,6 +3209,7 @@
|
|||||||
[
|
[
|
||||||
"ACE_AnyInputSwitchBool",
|
"ACE_AnyInputSwitchBool",
|
||||||
"ACE_AnyInputToAny",
|
"ACE_AnyInputToAny",
|
||||||
|
"ACE_AudioCrop",
|
||||||
"ACE_AudioLoad",
|
"ACE_AudioLoad",
|
||||||
"ACE_AudioPlay",
|
"ACE_AudioPlay",
|
||||||
"ACE_AudioSave",
|
"ACE_AudioSave",
|
||||||
@@ -3103,6 +3220,7 @@
|
|||||||
"ACE_ImageFaceCrop",
|
"ACE_ImageFaceCrop",
|
||||||
"ACE_ImageGetSize",
|
"ACE_ImageGetSize",
|
||||||
"ACE_ImageLoadFromCloud",
|
"ACE_ImageLoadFromCloud",
|
||||||
|
"ACE_ImageMakeSlieshow",
|
||||||
"ACE_ImagePixelate",
|
"ACE_ImagePixelate",
|
||||||
"ACE_ImageQA",
|
"ACE_ImageQA",
|
||||||
"ACE_ImageRemoveBackground",
|
"ACE_ImageRemoveBackground",
|
||||||
@@ -3121,6 +3239,7 @@
|
|||||||
"ACE_TextSelector",
|
"ACE_TextSelector",
|
||||||
"ACE_TextToResolution",
|
"ACE_TextToResolution",
|
||||||
"ACE_TextTranslate",
|
"ACE_TextTranslate",
|
||||||
|
"ACE_VideoConcat",
|
||||||
"ACE_VideoLoad",
|
"ACE_VideoLoad",
|
||||||
"ACE_VideoPreview"
|
"ACE_VideoPreview"
|
||||||
],
|
],
|
||||||
@@ -3285,6 +3404,14 @@
|
|||||||
"title_aux": "comfyui-hydit"
|
"title_aux": "comfyui-hydit"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/if-ai/ComfyUI-IF_Zonos": [
|
||||||
|
[
|
||||||
|
"IF_ZonosTTS"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "ComfyUI-IF_Zonos [WIP]"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/ilovejohnwhite/Tracer": [
|
"https://github.com/ilovejohnwhite/Tracer": [
|
||||||
[
|
[
|
||||||
"BillyGoatNode",
|
"BillyGoatNode",
|
||||||
@@ -3362,6 +3489,14 @@
|
|||||||
"title_aux": "ComfyUI-ComfyFluxSize [WIP]"
|
"title_aux": "ComfyUI-ComfyFluxSize [WIP]"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/jgbyte/ComfyUI-RandomCube": [
|
||||||
|
[
|
||||||
|
"RandomCubeGrid"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "ComfyUI-RandomCube [WIP]"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/jimmm-ai/TimeUi-a-ComfyUi-Timeline-Node": [
|
"https://github.com/jimmm-ai/TimeUi-a-ComfyUi-Timeline-Node": [
|
||||||
[
|
[
|
||||||
"jimmm.ai.TimelineUI"
|
"jimmm.ai.TimelineUI"
|
||||||
@@ -3469,6 +3604,7 @@
|
|||||||
],
|
],
|
||||||
"https://github.com/jonnydolake/ComfyUI-AIR-Nodes": [
|
"https://github.com/jonnydolake/ComfyUI-AIR-Nodes": [
|
||||||
[
|
[
|
||||||
|
"ExtractBlackLines",
|
||||||
"ForceMinimumBatchSize",
|
"ForceMinimumBatchSize",
|
||||||
"ImageCompositeChained",
|
"ImageCompositeChained",
|
||||||
"LineDetection",
|
"LineDetection",
|
||||||
@@ -3536,6 +3672,8 @@
|
|||||||
],
|
],
|
||||||
"https://github.com/kandy/ComfyUI-KAndy": [
|
"https://github.com/kandy/ComfyUI-KAndy": [
|
||||||
[
|
[
|
||||||
|
"KAndyBatch2Index",
|
||||||
|
"KAndyBatchIndex",
|
||||||
"KAndyCivitImagesAPI",
|
"KAndyCivitImagesAPI",
|
||||||
"KAndyCivitPromptAPI",
|
"KAndyCivitPromptAPI",
|
||||||
"KAndyImageSave",
|
"KAndyImageSave",
|
||||||
@@ -3641,6 +3779,7 @@
|
|||||||
"DownloadAndLoadHy3DDelightModel",
|
"DownloadAndLoadHy3DDelightModel",
|
||||||
"DownloadAndLoadHy3DPaintModel",
|
"DownloadAndLoadHy3DPaintModel",
|
||||||
"Hy3DApplyTexture",
|
"Hy3DApplyTexture",
|
||||||
|
"Hy3DBPT",
|
||||||
"Hy3DBakeFromMultiview",
|
"Hy3DBakeFromMultiview",
|
||||||
"Hy3DCameraConfig",
|
"Hy3DCameraConfig",
|
||||||
"Hy3DDelightImage",
|
"Hy3DDelightImage",
|
||||||
@@ -3780,7 +3919,8 @@
|
|||||||
"Custom_Save_Image",
|
"Custom_Save_Image",
|
||||||
"Display_Any",
|
"Display_Any",
|
||||||
"Image_Size_Extractor",
|
"Image_Size_Extractor",
|
||||||
"Strong_Prompt"
|
"Strong_Prompt",
|
||||||
|
"Tencent_Translater"
|
||||||
],
|
],
|
||||||
{
|
{
|
||||||
"title_aux": "KayTool"
|
"title_aux": "KayTool"
|
||||||
@@ -3813,6 +3953,17 @@
|
|||||||
"title_aux": "ComfyUI Flow Control [UNSTABLE]"
|
"title_aux": "ComfyUI Flow Control [UNSTABLE]"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/krisshen2021/comfyui_OpenRouterNodes": [
|
||||||
|
[
|
||||||
|
"OpenRouterOAINode_Infer",
|
||||||
|
"OpenRouterOAINode_Models",
|
||||||
|
"OpenRouterOAINode_hunyuanPrompt",
|
||||||
|
"OpenRouterOAINode_txt2imgPrompt"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "comfyui_OpenRouterNodes [WIP]"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/kuschanow/ComfyUI-SD-Slicer": [
|
"https://github.com/kuschanow/ComfyUI-SD-Slicer": [
|
||||||
[
|
[
|
||||||
"SdSlicer"
|
"SdSlicer"
|
||||||
@@ -3984,6 +4135,9 @@
|
|||||||
"HYCreateRegionalCond",
|
"HYCreateRegionalCond",
|
||||||
"HYFetaEnhance",
|
"HYFetaEnhance",
|
||||||
"HYFlowEditGuider",
|
"HYFlowEditGuider",
|
||||||
|
"HYFlowEditGuiderAdv",
|
||||||
|
"HYFlowEditGuiderCFG",
|
||||||
|
"HYFlowEditGuiderCFGAdv",
|
||||||
"HYFlowEditSampler",
|
"HYFlowEditSampler",
|
||||||
"HYForwardODESampler",
|
"HYForwardODESampler",
|
||||||
"HYInverseModelSamplingPred",
|
"HYInverseModelSamplingPred",
|
||||||
@@ -4076,6 +4230,8 @@
|
|||||||
],
|
],
|
||||||
"https://github.com/lum3on/comfyui_LLM_Polymath": [
|
"https://github.com/lum3on/comfyui_LLM_Polymath": [
|
||||||
[
|
[
|
||||||
|
"Helper",
|
||||||
|
"UCEEraserNode",
|
||||||
"polymath_SaveAbsolute",
|
"polymath_SaveAbsolute",
|
||||||
"polymath_chat",
|
"polymath_chat",
|
||||||
"polymath_scraper"
|
"polymath_scraper"
|
||||||
@@ -4148,6 +4304,14 @@
|
|||||||
"title_aux": "ComfyUI mashb1t nodes"
|
"title_aux": "ComfyUI mashb1t nodes"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/masmullin2000/ComfyUI-MMYolo": [
|
||||||
|
[
|
||||||
|
"MMFace_Finder"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "ComfyUI-MMYolo"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/mehbebe/ComfyLoraGallery": [
|
"https://github.com/mehbebe/ComfyLoraGallery": [
|
||||||
[
|
[
|
||||||
"LoraGallery"
|
"LoraGallery"
|
||||||
@@ -4311,6 +4475,14 @@
|
|||||||
"title_aux": "ComfyUI-Claude-I2T"
|
"title_aux": "ComfyUI-Claude-I2T"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/muvich3n/ComfyUI-Crop-Border": [
|
||||||
|
[
|
||||||
|
"CropImageBorder"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "ComfyUI-Crop-Border"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/myAiLemon/MagicAutomaticPicture": [
|
"https://github.com/myAiLemon/MagicAutomaticPicture": [
|
||||||
[
|
[
|
||||||
"EditableStringNode",
|
"EditableStringNode",
|
||||||
@@ -4502,6 +4674,14 @@
|
|||||||
"title_aux": "comfyui-keshigom_custom"
|
"title_aux": "comfyui-keshigom_custom"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"https://github.com/owengillett/ComfyUI-tilefusion": [
|
||||||
|
[
|
||||||
|
"VideoGridCombine"
|
||||||
|
],
|
||||||
|
{
|
||||||
|
"title_aux": "ComfyUI-tilefusion"
|
||||||
|
}
|
||||||
|
],
|
||||||
"https://github.com/oyvindg/ComfyUI-TrollSuite": [
|
"https://github.com/oyvindg/ComfyUI-TrollSuite": [
|
||||||
[
|
[
|
||||||
"BinaryImageMask",
|
"BinaryImageMask",
|
||||||
@@ -5270,6 +5450,7 @@
|
|||||||
[
|
[
|
||||||
"CLIPTranslatedNode",
|
"CLIPTranslatedNode",
|
||||||
"DownloadImageNode",
|
"DownloadImageNode",
|
||||||
|
"FillAlphaNode",
|
||||||
"FixUTF8StringNode",
|
"FixUTF8StringNode",
|
||||||
"ImageResizeNode",
|
"ImageResizeNode",
|
||||||
"ImageToVideoNode",
|
"ImageToVideoNode",
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -129,6 +129,16 @@
|
|||||||
],
|
],
|
||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "A forked version of ComfyUI_ExtraModels. (modified by Efficient-Large-Model)"
|
"description": "A forked version of ComfyUI_ExtraModels. (modified by Efficient-Large-Model)"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "Pablerdo",
|
||||||
|
"title": "ComfyUI-PSNodes",
|
||||||
|
"reference": "https://github.com/Pablerdo/ComfyUI-PSNodes",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/Pablerdo/ComfyUI-PSNodes"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A fork of KJNodes for ComfyUI.\nVarious quality of life -nodes for ComfyUI, mostly just visual stuff to improve usability"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
@@ -11,6 +11,36 @@
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
{
|
||||||
|
"author": "thanhduong0213929",
|
||||||
|
"title": "ComfyUI-DeepUnlock [REMOVED]",
|
||||||
|
"reference": "https://github.com/thanhduong0213929/ComfyUI-DeepUnlock",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/thanhduong0213929/ComfyUI-DeepUnlock"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "DeepFuze is a state-of-the-art deep learning tool that seamlessly integrates with ComfyUI to revolutionize facial transformations, lipsyncing, video generation, voice cloning, face swapping, and lipsync translation. Leveraging advanced algorithms, DeepFuze enables users to combine audio and video with unparalleled realism, ensuring perfectly synchronized facial movements. This innovative solution is ideal for content creators, animators, developers, and anyone seeking to elevate their video editing projects with sophisticated AI-driven features."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "pathway8-sudo",
|
||||||
|
"title": "RMBG [REMOVED]",
|
||||||
|
"reference": "https://github.com/pathway8-sudo/RMBG",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/pathway8-sudo/RMBG"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "This repository provides a custom node for ComfyUI, leveraging the BriaRMBG model to remove backgrounds from images and output a transparent PNG."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "iris-Neko",
|
||||||
|
"title": "ComfyUI_ascii_art [REMOVED]",
|
||||||
|
"reference": "https://github.com/iris-Neko/ComfyUI_ascii_art",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/iris-Neko/ComfyUI_ascii_art"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "ComfyUI node for [a/ASCII art controlnet](https://civitai.com/models/986392)"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"author": "apesplat",
|
"author": "apesplat",
|
||||||
"title": "ezXY scripts and nodes [NOT MAINTAINED]",
|
"title": "ezXY scripts and nodes [NOT MAINTAINED]",
|
||||||
|
|||||||
@@ -11,7 +11,382 @@
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
{
|
||||||
|
"author": "RodrigoSKohl",
|
||||||
|
"title": "Interior Design for Comfyui",
|
||||||
|
"reference": "https://github.com/RodrigoSKohl/InteriorDesign-for-ComfyUI",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/RodrigoSKohl/InteriorDesign-for-ComfyUI"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "This node is based on MykolaL/StableDesign"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "smthemex",
|
||||||
|
"title": "ComfyUI_YuE",
|
||||||
|
"reference": "https://github.com/smthemex/ComfyUI_YuE",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/smthemex/ComfyUI_YuE"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "[a/YuE](https://github.com/multimodal-art-projection/YuE) is a groundbreaking series of open-source foundation models designed for music generation, specifically for transforming lyrics into full songs (lyrics2song). you can use it in comfyUI"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "benda1989",
|
||||||
|
"title": "GKK·Sonic",
|
||||||
|
"reference": "https://github.com/benda1989/Sonic_ComfyUI",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/benda1989/Sonic_ComfyUI"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "a plugin of ComfyUI for Long Sonic"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "ainewsto",
|
||||||
|
"title": "Comfyui_Comfly",
|
||||||
|
"reference": "https://github.com/ainewsto/Comfyui_Comfly",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/ainewsto/Comfyui_Comfly"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "NODES: Comfly_Mj, Comfly_mjstyle, Comfly_upload, Comfly_Mju, Comfly_Mjv, Comfly_kling_videoPreview"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "svetozarov",
|
||||||
|
"title": "AS_GeminiCaptioning Node",
|
||||||
|
"reference": "https://github.com/svetozarov/AS_GeminiCaptioning",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/svetozarov/AS_GeminiCaptioning"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A ComfyUI node that combines an image with simple text parameters to create a prompt, sends it to the Google Gemini API via the google-generativeai SDK, and returns the generated text response along with the original prompt and an execution log"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "Pablerdo",
|
||||||
|
"title": "ComfyUI-MultiCutAndDrag",
|
||||||
|
"reference": "https://github.com/Pablerdo/ComfyUI-MultiCutAndDrag",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/Pablerdo/ComfyUI-MultiCutAndDrag"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Cut and and drag that allows you to cut and drag multiple images on a path"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "LAOGOU-666",
|
||||||
|
"title": "ComfyUI-LG_HotReload",
|
||||||
|
"id": "ComfyUI-LG_HotReload",
|
||||||
|
"reference": "https://github.com/LAOGOU-666/Comfyui-LG_HotReload",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/LAOGOU-666/Comfyui-LG_HotReload"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "An extension for ComfyUI that allows hot reloading. Once installed, you can preview changes in real-time while developing custom nodes or installing plugins without restarting ComfyUI."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "fairy-root",
|
||||||
|
"title": "ComfyUI-Show-Text",
|
||||||
|
"reference": "https://github.com/fairy-root/ComfyUI-Show-Text",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/fairy-root/ComfyUI-Show-Text"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A simple but powerful node for ComfyUI that displays text input in a readable format. Perfect for viewing outputs from text generation nodes, prompt builders, interrogators, and more."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "Taremin",
|
||||||
|
"title": "comfyui-keep-multiple-tabs",
|
||||||
|
"reference": "https://github.com/Taremin/comfyui-keep-multiple-tabs",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/Taremin/comfyui-keep-multiple-tabs"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "This is an extension for ComfyUI. It retains multiple workflow tabs so that they are not lost when reloading or restarting."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "Shiba-2-shiba",
|
||||||
|
"title": "ComfyUI_FreeU_V2_timestepadd",
|
||||||
|
"id": "ComfyUI_FreeU_V2_timestepadd",
|
||||||
|
"reference": "https://github.com/Shiba-2-shiba/ComfyUI_FreeU_V2_timestepadd",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/Shiba-2-shiba/ComfyUI_FreeU_V2_timestepadd"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "This is a custom node to add timestep for FreeU V2."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "MeeeyoAI",
|
||||||
|
"title": "ComfyUI_StringOps",
|
||||||
|
"reference": "https://github.com/MeeeyoAI/ComfyUI_StringOps",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/MeeeyoAI/ComfyUI_StringOps"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "StringOps is a versatile text processing toolkit built for ComfyUI's node-based workflows"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "crave33",
|
||||||
|
"title": "RenesStuffDanboruTagGet",
|
||||||
|
"reference": "https://github.com/crave33/RenesStuffDanboruTagGet",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/crave33/RenesStuffDanboruTagGet"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "generate tags / prompt from danboru image_id input"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "smthemex",
|
||||||
|
"title": "ComfyUI_Light_A_Video",
|
||||||
|
"reference": "https://github.com/smthemex/ComfyUI_Light_A_Video",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/smthemex/ComfyUI_Light_A_Video"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Light-A-Video: Training-free Video Relighting via Progressive Light Fusion,you can use it in comfyUI"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "Easymode-ai",
|
||||||
|
"title": "ComfyUI-ShadowR",
|
||||||
|
"reference": "https://github.com/Easymode-ai/ComfyUI-ShadowR",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/Easymode-ai/ComfyUI-ShadowR"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "ComfyUI [a/movingforward100/Shadow_R](https://github.com/movingforward100/Shadow_R) Wrapper"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "chenlongming",
|
||||||
|
"title": "ComfyUI_Spectral",
|
||||||
|
"reference": "https://github.com/chenlongming/ComfyUI_Spectral",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/chenlongming/ComfyUI_Spectral"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "ComfyUI Spectral is a ComfyUI custom nodes library based on the spectral, mainly used for visual processing of spectral files"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "Chengym2023",
|
||||||
|
"title": "ComfyUI-DeepSeek_Online",
|
||||||
|
"reference": "https://github.com/Chengym2023/ComfyUI-DeepSeek_Online",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/Chengym2023/ComfyUI-DeepSeek_Online"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "NODES: SiliconCloudReasoning, DeepSeekOnline"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "gitmylo",
|
||||||
|
"title": "Audio nodes",
|
||||||
|
"reference": "https://github.com/gitmylo/ComfyUI-audio-nodes",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/gitmylo/ComfyUI-audio-nodes"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Various nodes related to audio."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "billwuhao",
|
||||||
|
"title": "ComfyUI_StepAudioTTS",
|
||||||
|
"reference": "https://github.com/billwuhao/ComfyUI_StepAudioTTS",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/billwuhao/ComfyUI_StepAudioTTS"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A Text To Speech node using Step-Audio-TTS in ComfyUI. Can speak, rap, sing, or clone voice."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "greengerong",
|
||||||
|
"title": "ComfyUI-Lumina-Video",
|
||||||
|
"reference": "https://github.com/greengerong/ComfyUI-Lumina-Video",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/greengerong/ComfyUI-Lumina-Video"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "This is a video generation plugin implementation for ComfyUI based on the Lumina Video model."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "morgan55555",
|
||||||
|
"title": "ComfyUI Lock Mode",
|
||||||
|
"reference": "https://github.com/morgan55555/comfyui-lock-mode",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/morgan55555/comfyui-lock-mode"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Lock Mode feature for ComfyUI. Make simple no-code UI easily."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "aicuai",
|
||||||
|
"title": "aicu-comfyui-stability-ai-api",
|
||||||
|
"reference": "https://github.com/aicuai/aicu-comfyui-stability-ai-api",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/aicuai/aicu-comfyui-stability-ai-api"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "This repository contains custom nodes for Stability AI API which supports SD3.0 and 3.5."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "benda1989",
|
||||||
|
"title": "CosyVoice2 for ComfyUI",
|
||||||
|
"reference": "https://github.com/benda1989/CosyVoice2_ComfyUI",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/benda1989/CosyVoice2_ComfyUI"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A plugin of ComfyUI for CosyVoice2, one component for text to Sonic Video"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "alessandrozonta",
|
||||||
|
"title": "Comfyui-LoopLoader",
|
||||||
|
"id": "Comfyui-LoopLoader",
|
||||||
|
"reference": "https://github.com/alessandrozonta/Comfyui-LoopLoader",
|
||||||
|
"files": [
|
||||||
|
"hhttps://github.com/alessandrozonta/Comfyui-LoopLoader"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A ComfyUI custom node for loading images sequentially from a directory. Loops back to the first image when reaching the end"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "AEmotionStudio",
|
||||||
|
"title": "ComfyUI-EnhancedLinksandNodes 🎨✨",
|
||||||
|
"reference": "https://github.com/AEmotionStudio/ComfyUI-EnhancedLinksandNodes",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/AEmotionStudio/ComfyUI-EnhancedLinksandNodes"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A visually stunning extension for ComfyUI that adds beautiful, customizable animations to both links and nodes in your workflow, with a focus on performance and customization. Includes an end-of-render animation and a text visibility tool for nodes. No extra packages are required, works with the latest version of ComfyUI, and should be compatible with most workflows. Larger workflows may experience performance issues, especially if you have a lot of nodes and are using a lower end system."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "pathway8-sudo",
|
||||||
|
"title": "ComfyUI-Pathway-CutPNG-Node",
|
||||||
|
"reference": "https://github.com/pathway8-sudo/ComfyUI-Pathway-CutPNG-Node",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/pathway8-sudo/ComfyUI-Pathway-CutPNG-Node"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Custom ComfyUI node that uses BRIA RMBG v1.4 for background removal and PNG cutting."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "quadmoon",
|
||||||
|
"title": "ComfyUI-UltimateSDUpscale-GGUF",
|
||||||
|
"reference": "https://github.com/traugdor/ComfyUI-UltimateSDUpscale-GGUF",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/traugdor/ComfyUI-UltimateSDUpscale-GGUF"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "GGUF implementation for the ComfyUI Ultimate SD Upscale node."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "dasilva333",
|
||||||
|
"title": "ComfyUI_MarkdownImage",
|
||||||
|
"reference": "https://github.com/dasilva333/ComfyUI_MarkdownImage",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/dasilva333/ComfyUI_MarkdownImage"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "This project generates an image from Markdown text using imgkit and wkhtmltoimage. It automatically scales the text to fit within the specified image dimensions."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "GamingDaveUk",
|
||||||
|
"title": "Daves Nodes",
|
||||||
|
"id": "davesnodes",
|
||||||
|
"reference": "https://github.com/GamingDaveUk/daves_nodes",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/GamingDaveUk/daves_nodes"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Nodes that I needed but couldnt find, so ended up making."
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
"author": "AIFSH",
|
||||||
|
"title": "SemiChat-ComfyUI",
|
||||||
|
"reference": "https://github.com/AIFSH/SemiChat-ComfyUI",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/AIFSH/SemiChat-ComfyUI"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A ComfyUI chat node based on SemiUI."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "AIDC-AI",
|
||||||
|
"title": "ComfyUI-Copilot",
|
||||||
|
"id": "ComfyUI-Copilot",
|
||||||
|
"reference": "https://github.com/AIDC-AI/ComfyUI-Copilot",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/AIDC-AI/ComfyUI-Copilot"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Your Intelligent Assistant for Comfy-UI."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "RodrigoSKohl",
|
||||||
|
"title": "Interior Design for Comfyui",
|
||||||
|
"reference": "https://github.com/RodrigoSKohl/StableDesign-for-ComfyUI",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/RodrigoSKohl/StableDesign-for-ComfyUI"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "This node is based on MykolaL/StableDesign"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "attashe",
|
||||||
|
"title": "ComfyUI-FluxRegionAttention",
|
||||||
|
"reference": "https://github.com/attashe/ComfyUI-FluxRegionAttention",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/attashe/ComfyUI-FluxRegionAttention"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Implement Region Attention for Flux model. Add node RegionAttention that takes a regions - mask + condition, mask could be set from comfyui masks or bbox in FluxRegionBBOX node.\nThis code is not optimized and has a memory leak. If you caught a OOM just try run a query againg - works on my RTX3080. For generation it uses a usual prompt that have influence to all picture and a regions that have their own prompts.\nBase prompt good for setup background and style of image. This is train-free technique and results not always stable - sometimes need to try several seeds or change prompt."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "yas-ponotech",
|
||||||
|
"title": "ComfyUI-Stability-AI-API",
|
||||||
|
"reference": "https://github.com/yhayano-ponotech/comfyui-stability-ai-api",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/yhayano-ponotech/comfyui-stability-ai-api"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A collection of custom nodes for using the Stability AI API in ComfyUI."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "HJH-AILab",
|
||||||
|
"title": "ComfyUI_StableAnimator",
|
||||||
|
"reference": "https://github.com/HJH-AILab/ComfyUI_StableAnimator",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/HJH-AILab/ComfyUI_StableAnimator"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "ComfyUI nodes for StableAnimator"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "kevinmcmahondev",
|
||||||
|
"title": "KMCDev Nodes",
|
||||||
|
"reference": "https://github.com/kevinmcmahondev/comfyui-kmcdev-image-filter-adjustments",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/kevinmcmahondev/comfyui-kmcdev-image-filter-adjustments"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A ComfyUI node that provides advanced image adjustment filters and controls for image manipulation"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "lunarring",
|
||||||
|
"title": "bitalino_comfy",
|
||||||
|
"reference": "https://github.com/lunarring/bitalino_comfy",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/lunarring/bitalino_comfy"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "A package implementing a Bitalino device ComfyUI custom node."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "Hellfiredragon",
|
||||||
|
"title": "comfyui-image-manipulation",
|
||||||
|
"reference": "https://github.com/Hellfiredragon/comfyui-image-manipulation",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/Hellfiredragon/comfyui-image-manipulation"
|
||||||
|
],
|
||||||
|
"install_type": "git-clone",
|
||||||
|
"description": "Custom nodes to manipulate images in ComfyUI"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"author": "Mohammadreza Mohseni",
|
"author": "Mohammadreza Mohseni",
|
||||||
"title": "ComfyUI Mohseni Kit",
|
"title": "ComfyUI Mohseni Kit",
|
||||||
@@ -32,7 +407,7 @@
|
|||||||
"https://github.com/BlueprintCoding/ComfyUI_AIDocsClinicalTools"
|
"https://github.com/BlueprintCoding/ComfyUI_AIDocsClinicalTools"
|
||||||
],
|
],
|
||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "MultiInt and MultiText nodes. The MultiInt node allows management of multiple int values with configurable steps, +/- buttons, drag change, & customized labels. The MultiText node offers similar functionality for string values."
|
"description": "Nodes: Multi Int and Multi Text; allows for the creation of multiple int and multiple string storage and output from a single node. Multi Float coming soon."
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"author": "CY-CHENYUE",
|
"author": "CY-CHENYUE",
|
||||||
@@ -307,393 +682,6 @@
|
|||||||
],
|
],
|
||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "ComfyUI node for [a/ASCII art controlnet](https://civitai.com/models/986392)"
|
"description": "ComfyUI node for [a/ASCII art controlnet](https://civitai.com/models/986392)"
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "yichengup",
|
|
||||||
"title": "ComfyUI-YCNodes",
|
|
||||||
"reference": "https://github.com/yichengup/ComfyUI-YCNodes",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/yichengup/ComfyUI-YCNodes"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "A collection of image processing extension nodes for ComfyUI."
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "ShinChven",
|
|
||||||
"title": "ShinChven's Custom Nodes Package",
|
|
||||||
"reference": "https://github.com/ShinChven/sc-comfy-nodes",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/ShinChven/sc-comfy-nodes"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "This project contains custom nodes for ComfyUI, developed by ShinChven. The nodes in this package extend the functionality of ComfyUI by providing additional features and utilities."
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "lingha",
|
|
||||||
"title": "comfyui_kj",
|
|
||||||
"id": "comfyui_kj",
|
|
||||||
"reference": "https://github.com/lingha0h/comfyui_kj",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/lingha0h/comfyui_kj"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "comfyui_kj, A tool that can package workflows into projects and publish them to a WeChat Mini Program named Kaji, allowing charges to be collected from users."
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "asdrabael",
|
|
||||||
"title": "Hunyuan-Multi-Lora-Loader",
|
|
||||||
"id": "Hunyuan Multi-Lora Loader",
|
|
||||||
"reference": "https://github.com/asdrabael/Hunyuan-Multi-Lora-Loader",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/asdrabael/Hunyuan-Multi-Lora-Loader"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "ComfyUI Node for loading multiple Lora's [a/HunyuanVideo](https://github.com/Tencent/HunyuanVideo)"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "vahlok-alunmid",
|
|
||||||
"title": "ComfyUI-ExtendIPAdapterClipVision",
|
|
||||||
"reference": "https://github.com/vahlok-alunmid/ComfyUI-ExtendIPAdapterClipVision",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/vahlok-alunmid/ComfyUI-ExtendIPAdapterClipVision"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "This extension provides two nodes to use with my experimental [a/ip-adapter finetune](https://civitai.com/models/1233692?modelVersionId=1390253) for NoobAI-XL style transfer. [a/Here](https://github.com/vahlok-alunmid/reForge-preprocessor_bigG_448) is the counterpart extension for Reforge WebUI."
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "yanhuifair",
|
|
||||||
"title": "comfyui-janus",
|
|
||||||
"reference": "https://github.com/yanhuifair/comfyui-janus",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/yanhuifair/comfyui-janus"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "ComfyUI nodes for Janus"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "guerreiro",
|
|
||||||
"title": "Comfyg Switch",
|
|
||||||
"reference": "https://github.com/guerreiro/comfyg-switch",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/guerreiro/comfyg-switch"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "Comfyg Switch is a custom node that dynamically selects model configuration parameters based on the chosen checkpoint. It reads model-specific settings from a JSON file (model_configs.json)."
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "dorpxam",
|
|
||||||
"title": "ComfyUI-LTXVideoLoRA",
|
|
||||||
"reference": "https://github.com/dorpxam/ComfyUI-LTXVideoLoRA",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/dorpxam/ComfyUI-LTXVideoLoRA"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "A set of custom nodes enabling LoRA support for LTX Video"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "DriftJohnson",
|
|
||||||
"title": "KokoroTTS Node",
|
|
||||||
"reference": "https://github.com/MushroomFleet/DJZ-KokoroTTS",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/MushroomFleet/DJZ-KokoroTTS"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "This node provides advanced text-to-speech functionality powered by KokoroTTS. Follow the instructions below to install, configure, and use the node within your portable ComfyUI installation."
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "zentrocdot",
|
|
||||||
"title": "ComfyUI-RealESRGAN_Upscaler",
|
|
||||||
"reference": "https://github.com/zentrocdot/ComfyUI-RealESRGAN_Upscaler",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/zentrocdot/ComfyUI-RealESRGAN_Upscaler"
|
|
||||||
],
|
|
||||||
"description": "This node uses the RealESRGAN model from [a/xinntao](https://github.com/xinntao/Real-ESRGAN).",
|
|
||||||
"install_type": "git-clone"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "smthemex",
|
|
||||||
"title": "ComfyUI_DiffuEraser",
|
|
||||||
"reference": "https://github.com/smthemex/ComfyUI_DiffuEraser",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/smthemex/ComfyUI_DiffuEraser"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "DiffuEraser is a diffusion model for video Inpainting, you can use it in ComfyUI"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "smthemex",
|
|
||||||
"title": "ComfyUI_CSD_MT",
|
|
||||||
"reference": "https://github.com/smthemex/ComfyUI_CSD_MT",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/smthemex/ComfyUI_CSD_MT"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "[a/CSD_MT](https://github.com/Snowfallingplum/CSD-MT) is a method about 'Content-Style Decoupling for Unsupervised Makeup Transfer without Generating Pseudo Ground Truth', you can use it in comfyUI."
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "Extraltodeus",
|
|
||||||
"title": "Negative-attention-for-ComfyUI-",
|
|
||||||
"reference": "https://github.com/Extraltodeus/Negative-attention-for-ComfyUI-",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/Extraltodeus/Negative-attention-for-ComfyUI-"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "Takes the difference in between the positive and negative conditioning at the attention.\nNOTE: Will not work with Flux"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "magekinnarus",
|
|
||||||
"title": "ComfyUI-V-Prediction-Node",
|
|
||||||
"reference": "https://github.com/magekinnarus/ComfyUI-V-Prediction-Node",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/magekinnarus/ComfyUI-V-Prediction-Node"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "Node to set v-prediction sampling when using SDXL and other models that may not have the necessary metadata to identify it as a v-prediction model. This node is useful for quantized models since they lack the necessary metadata."
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "raindrop313",
|
|
||||||
"title": "ComfyUI_SD3_Flowedit",
|
|
||||||
"reference": "https://github.com/raindrop313/ComfyUI_SD3_Flowedit",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/raindrop313/ComfyUI_SD3_Flowedit"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "ComfyUI nodes that support SD3/SD3.5 in FlowEdit"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "martin-rizzo",
|
|
||||||
"title": "ComfyUI-TinyBreaker",
|
|
||||||
"reference": "https://github.com/martin-rizzo/ComfyUI-TinyBreaker",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/martin-rizzo/ComfyUI-TinyBreaker"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "ComfyUI-TinyBreaker is a collection of custom nodes specifically designed to generate images using the TinyBreaker model. It's actively developed with ongoing improvements. Although still in progress, these nodes are functional and allow you to explore the potential of the model."
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "melMass",
|
|
||||||
"title": "comfy-oiio",
|
|
||||||
"reference": "https://github.com/melMass/comfy_oiio",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/melMass/comfy_oiio"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "OpenImageIO plugin for ComfyUI"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "KLL535",
|
|
||||||
"title": "ComfyUI_PNGInfo_Sidebar",
|
|
||||||
"reference": "https://github.com/KLL535/ComfyUI_PNGInfo_Sidebar",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/KLL535/ComfyUI_PNGInfo_Sidebar"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "Frontend extension that adds a sidebar for easy viewing of PNG file metadata."
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "greengerong",
|
|
||||||
"title": "Janus-Pro ComfyUI Plugin",
|
|
||||||
"reference": "https://github.com/greengerong/ComfyUI-JanusPro-PL",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/greengerong/ComfyUI-JanusPro-PL"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "This plugin integrates the Janus-Pro multi-modal model into ComfyUI, enabling advanced image understanding and text-to-image generation capabilities. It supports both image analysis and creative image generation workflows."
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "smthemex",
|
|
||||||
"title": "ComfyUI_Sonic",
|
|
||||||
"reference": "https://github.com/smthemex/ComfyUI_Sonic",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/smthemex/ComfyUI_Sonic"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "Sonic is a method about ' Shifting Focus to Global Audio Perception in Portrait Animation',you can use it in comfyUI."
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "satche",
|
|
||||||
"title": "Prompt Factory",
|
|
||||||
"reference": "https://github.com/satche/comfyui-prompt-factory",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/satche/comfyui-prompt-factory"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "A modular system that adds randomness to prompt generation"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "hdfhssg",
|
|
||||||
"title": "ComfyUI_pxtool",
|
|
||||||
"reference": "https://github.com/hdfhssg/ComfyUI_pxtool",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/hdfhssg/ComfyUI_pxtool"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "This is a custom plugin node for ComfyUI that modifies and extends some features from existing projects. The main implementations include:\n* Reproducing some features of the [a/Stable-Diffusion-Webui-Civitai-Helper](https://github.com/zixaphir/Stable-Diffusion-Webui-Civitai-Helper) project within ComfyUI\n* Implementing a feature to randomly generate related prompt words by referencing the [a/noob-wiki dataset](https://huggingface.co/datasets/Laxhar/noob-wiki/tree/main)"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "CC-SUN6",
|
|
||||||
"title": "ccsun_node",
|
|
||||||
"reference": "https://github.com/CC-SUN6/ccsun_node",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/CC-SUN6/ccsun_node"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "About the comfyui image selector, image adjustment (panning, rotation, zoom), adjust image size to be a multiple of 8"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "DiaoDaiaChan",
|
|
||||||
"title": "Comfyui SDAPI Request / NovelAI",
|
|
||||||
"id": "diaodaiachan",
|
|
||||||
"reference": "https://github.com/DiaoDaiaChan/ComfyUI_API_Request",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/DiaoDaiaChan/ComfyUI_API_Request"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "A Novel AI / SD-WebUI request node, support nai3/nai4, use NovelAI model in Your Comfyui."
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "hgabha",
|
|
||||||
"title": "WWAA-CustomNodes",
|
|
||||||
"reference": "https://github.com/hgabha/WWAA-CustomNodes",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/hgabha/WWAA-CustomNodes"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "Custom Nodes by the team at WeirdWonderfulAI.Art. Line Count, Join String, Dither Image, Image Batch Loader, Prompt Writer"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "slvslvslv",
|
|
||||||
"title": "ComfyUI Smart Helper Nodes",
|
|
||||||
"reference": "https://github.com/slvslvslv/ComfyUI-SmartHelperNodes",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/slvslvslv/ComfyUI-SmartHelperNodes"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "NODES: Smart HunyuanVideo Lora Select, Smart HunyuanVideo Lora StackSmart Format String, Smart Format String (10 params)"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "Tr1dae",
|
|
||||||
"title": "ComfyUI-Dequality",
|
|
||||||
"reference": "https://github.com/Tr1dae/ComfyUI-Dequality",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/Tr1dae/ComfyUI-Dequality"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "Simple addition to add noise to an image. Found on reddit"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "DragonDiffusionbyBoyo",
|
|
||||||
"title": "Boyonodes",
|
|
||||||
"reference": "https://github.com/DragonDiffusionbyBoyo/Boyonodes",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/DragonDiffusionbyBoyo/Boyonodes"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "The Vae node is a sneaky little node perfect for deployment in Schools or work environments where you do not want the kiddywinkles creating NSFW content. Just rename the node to VAE decode and it looks like a normal node but hidden inside is an NSFW detector. Once hidden in the workflow there are no settings to undo the NSFW detection so cannot be worked around unless you remove the node. The node looks innocent once renamed so is virtually undetectable. I have placed an example workflow for you to see how to connect it. Simple stuff really, but once connected just rename."
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "lldacing",
|
|
||||||
"title": "ComfyUI_BEN_ll",
|
|
||||||
"reference": "https://github.com/lldacing/ComfyUI_BEN_ll",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/lldacing/ComfyUI_BEN_ll"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "Background removal based on BEN. NODES:LoadRembgByBenModel, RembgByBen, GetMaskByBen, RembgByBenAdvanced, BlurFusionForegroundEstimation."
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "ShmuelRonen",
|
|
||||||
"title": "ComfyUI-JoyHallo_wrapper",
|
|
||||||
"reference": "https://github.com/ShmuelRonen/ComfyUI-JoyHallo_wrapper",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/ShmuelRonen/ComfyUI-JoyHallo_wrapper"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "A ComfyUI custom node wrapper for JoyHallo - One-Shot Audio-Driven Talking Head Generation."
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "gorillaframeai",
|
|
||||||
"title": "GF_translate",
|
|
||||||
"reference": "https://github.com/gorillaframeai/GF_translate",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/gorillaframeai/GF_translate"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "These custom nodes for ComfyUI provide advanced text translation capabilities using Google Translate. They are designed for seamless integration into the ComfyUI environment, offering users powerful tools for text and JSON file translation tasks."
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "StarAsh042",
|
|
||||||
"title": "ComfyUI_RollingArtist",
|
|
||||||
"reference": "https://github.com/StarAsh042/ComfyUI_RollingArtist",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/StarAsh042/ComfyUI_RollingArtist"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "RollingArtist is a ComfyUI node designed to generate artist prompt texts with random weights, suitable for text-to-image generation models. The node reads an artist list from a CSV file and generates combined prompts based on the parameters."
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "Arkanun",
|
|
||||||
"title": "ReadCSV_ComfyUI",
|
|
||||||
"reference": "https://github.com/Arkanun/ReadCSV_ComfyUI",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/Arkanun/ReadCSV_ComfyUI"
|
|
||||||
],
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"description": "NODES: ReadCSVRowNode"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "zentrocdot",
|
|
||||||
"title": "ComfyUI_Circle_Detection",
|
|
||||||
"reference": "https://github.com/zentrocdot/ComfyUI_Circle_Detection",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/zentrocdot/ComfyUI_Circle_Detection"
|
|
||||||
],
|
|
||||||
"description": "Next to AI mathematical methods can be used for the detection of objects like a circle.",
|
|
||||||
"install_type": "git-clone"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "AiartvnTeam",
|
|
||||||
"title": "A2V Multi Image Composite",
|
|
||||||
"id": "Aiartvn",
|
|
||||||
"reference": "https://github.com/aiartvn/A2V_Multi_Image_Composite",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/aiartvn/A2V_Multi_Image_Composite"
|
|
||||||
],
|
|
||||||
"description": "Node for compositing multiple images with interactive preview and layer management",
|
|
||||||
"install_type": "git-clone",
|
|
||||||
"tags": ["image", "composite", "layer", "blend", "transform"]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"author": "ProGamerGov",
|
|
||||||
"title": "Preview 360 Panorama for ComfyUI",
|
|
||||||
"id": "comfyui-preview360panorama",
|
|
||||||
"reference": "https://github.com/ProGamerGov/ComfyUI_preview360panorama",
|
|
||||||
"files": [
|
|
||||||
"https://github.com/ProGamerGov/ComfyUI_preview360panorama"
|
|
||||||
],
|
|
||||||
"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.."
|
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -1,5 +1,28 @@
|
|||||||
{
|
{
|
||||||
"models": [
|
"models": [
|
||||||
|
{
|
||||||
|
"name": "kolors/vae/diffusion_pytorch_model.fp16.safetensors",
|
||||||
|
"type": "VAE",
|
||||||
|
"base": "Kolors",
|
||||||
|
"save_path": "vae/kolors",
|
||||||
|
"description": "Kolors VAE",
|
||||||
|
"reference": "https://huggingface.co/Kwai-Kolors/Kolors",
|
||||||
|
"filename": "diffusion_pytorch_model.fp16.safetensors",
|
||||||
|
"url": "https://huggingface.co/Kwai-Kolors/Kolors/resolve/main/vae/diffusion_pytorch_model.fp16.safetensors",
|
||||||
|
"size": "167MB"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "kolors/vae/diffusion_pytorch_model.safetensors",
|
||||||
|
"type": "VAE",
|
||||||
|
"base": "Kolors",
|
||||||
|
"save_path": "vae/kolors",
|
||||||
|
"description": "Kolors VAE",
|
||||||
|
"reference": "https://huggingface.co/Kwai-Kolors/Kolors",
|
||||||
|
"filename": "diffusion_pytorch_model.safetensors",
|
||||||
|
"url": "https://huggingface.co/Kwai-Kolors/Kolors/resolve/main/vae/diffusion_pytorch_model.safetensors",
|
||||||
|
"size": "335MB"
|
||||||
|
},
|
||||||
|
|
||||||
{
|
{
|
||||||
"name": "deepseek-ai/Janus-Pro-1B",
|
"name": "deepseek-ai/Janus-Pro-1B",
|
||||||
"type": "Janus-Pro",
|
"type": "Janus-Pro",
|
||||||
|
|||||||
@@ -301,6 +301,16 @@
|
|||||||
],
|
],
|
||||||
"install_type": "git-clone",
|
"install_type": "git-clone",
|
||||||
"description": "This project is generated from xhiroga/ComfyUI-TypeScript-CustomNode"
|
"description": "This project is generated from xhiroga/ComfyUI-TypeScript-CustomNode"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"author": "zentrocdot",
|
||||||
|
"title": "ComfyUI-Turtle_Graphics_Demos",
|
||||||
|
"reference": "https://github.com/zentrocdot/ComfyUI-Turtle_Graphics_Demo",
|
||||||
|
"files": [
|
||||||
|
"https://github.com/zentrocdot/ComfyUI-Turtle_Graphics_Demo"
|
||||||
|
],
|
||||||
|
"description": "ComfyUI node for creating some Turtle Graphic demos.",
|
||||||
|
"install_type": "git-clone"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
@@ -95,7 +95,7 @@ def read_config():
|
|||||||
global default_conf
|
global default_conf
|
||||||
try:
|
try:
|
||||||
import configparser
|
import configparser
|
||||||
config = configparser.ConfigParser()
|
config = configparser.ConfigParser(strict=False)
|
||||||
config.read(manager_config_path)
|
config.read(manager_config_path)
|
||||||
default_conf = config['default']
|
default_conf = config['default']
|
||||||
except Exception:
|
except Exception:
|
||||||
@@ -787,7 +787,7 @@ if script_executed:
|
|||||||
def check_windows_event_loop_policy():
|
def check_windows_event_loop_policy():
|
||||||
try:
|
try:
|
||||||
import configparser
|
import configparser
|
||||||
config = configparser.ConfigParser()
|
config = configparser.ConfigParser(strict=False)
|
||||||
config.read(manager_config_path)
|
config.read(manager_config_path)
|
||||||
default_conf = config['default']
|
default_conf = config['default']
|
||||||
|
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
[project]
|
[project]
|
||||||
name = "comfyui-manager"
|
name = "comfyui-manager"
|
||||||
description = "ComfyUI-Manager provides features to install and manage custom nodes for ComfyUI, as well as various functionalities to assist with ComfyUI."
|
description = "ComfyUI-Manager provides features to install and manage custom nodes for ComfyUI, as well as various functionalities to assist with ComfyUI."
|
||||||
version = "3.23"
|
version = "3.26"
|
||||||
license = { file = "LICENSE.txt" }
|
license = { file = "LICENSE.txt" }
|
||||||
dependencies = ["GitPython", "PyGithub", "matrix-client==0.4.0", "transformers", "huggingface-hub>0.20", "typer", "rich", "typing-extensions"]
|
dependencies = ["GitPython", "PyGithub", "matrix-client==0.4.0", "transformers", "huggingface-hub>0.20", "typer", "rich", "typing-extensions", "toml", "uv", "chardet"]
|
||||||
|
|
||||||
[project.urls]
|
[project.urls]
|
||||||
Repository = "https://github.com/ltdrdata/ComfyUI-Manager"
|
Repository = "https://github.com/ltdrdata/ComfyUI-Manager"
|
||||||
|
|||||||
Reference in New Issue
Block a user