Compare commits

...

6 Commits

Author SHA1 Message Date
Dr.Lt.Data
cee4fdcbb0 fixed: apply ConfigParser(strict=False) to other callsites
https://github.com/ltdrdata/ComfyUI-Manager/pull/1561
2025-02-19 22:07:47 +09:00
Vanisper
df3cdfccb0 fix(git_utils): allow duplicate vscode-merge-base sections with strict=False (#1561)
- Set ConfigParser strict mode to False
- Resolves issue #1529 by permitting section duplicates
- Allow `vscode-merge-base` to appear multiple times in `.git/config`
2025-02-19 22:05:04 +09:00
Dr.Lt.Data
894042cd0e update DB 2025-02-19 22:02:10 +09:00
jmjoy
8123287952 Update model-list.json (#1564) 2025-02-19 21:40:20 +09:00
puke
bc677705d8 Update custom-node-list.json (#1562) 2025-02-19 21:39:41 +09:00
Dr.Lt.Data
5dd8ea8aab feat: update policy for updating ComfyUI
https://github.com/ltdrdata/ComfyUI-Manager/issues/1552

fixed: comfyui versions should be based on commit date
https://github.com/ltdrdata/ComfyUI-Manager/issues/1566

fixed: invalid identifying of nightly node packs which has `git@github.com:...` url
fixed: switch comfyui should be based on `master` branch instead of `main` branch
fixed: switch_to_default_branch - more robust switching
refactor: endpoints for policies
2025-02-19 21:34:13 +09:00
20 changed files with 3355 additions and 2887 deletions

View File

@@ -76,7 +76,7 @@ core.check_invalid_nodes()
def read_downgrade_blacklist():
try:
import configparser
config = configparser.ConfigParser()
config = configparser.ConfigParser(strict=False)
config.read(core.manager_config.path)
default_conf = config['default']

View File

@@ -18972,6 +18972,16 @@
"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."
},
{
"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",
"title": "seamless-clone-comfyui",
@@ -21034,6 +21044,59 @@
"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"
},

View File

@@ -58,6 +58,7 @@
],
"https://github.com/1038lab/ComfyUI-RMBG": [
[
"BiRefNet",
"ClothesSegment",
"FaceSegment",
"FashionSegmentAccessories",
@@ -1381,6 +1382,12 @@
"Faishme Load Image from Glob",
"Faishme Mannequin to Model Loader",
"Faishme Moondream",
"Faishme Repeat Image Batch",
"Faishme Repeat Latent Batch",
"Faishme Stack Images",
"Faishme Stack Latents",
"Faishme Unstack Images",
"Faishme Unstack Latents",
"Load Fashion Model"
],
{
@@ -4187,6 +4194,15 @@
"title_aux": "ComfyUI-FilePathCreator"
}
],
"https://github.com/HJH-AILab/ComfyUI_StableAnimator": [
[
"StableAnimatorModels",
"StableAnimatorNode"
],
{
"title_aux": "ComfyUI_StableAnimator"
}
],
"https://github.com/HM-RunningHub/ComfyUI_RH_APICall": [
[
"RH_BatchImages",
@@ -7447,6 +7463,14 @@
"title_aux": "Panoramic Image Stitcher"
}
],
"https://github.com/RodrigoSKohl/StableDesign-for-ComfyUI": [
[
"interior-design-for-comfyui"
],
{
"title_aux": "Interior Design for Comfyui"
}
],
"https://github.com/RodrigoSKohl/comfyui-tryoff-anyone": [
[
"TryOffAnyoneNode"
@@ -8134,7 +8158,8 @@
],
"https://github.com/ShinChven/sc-comfy-nodes": [
[
"Rescale Node"
"Rescale Node",
"Width & Height"
],
{
"title_aux": "ShinChven's Custom Nodes Package"
@@ -11717,6 +11742,20 @@
"title_aux": "Core ML Suite for ComfyUI"
}
],
"https://github.com/attashe/ComfyUI-FluxRegionAttention": [
[
"BBoxToMaskNode",
"BoundingBoxNode",
"CLIPDebug",
"FluxRegionBBOX",
"FluxRegionMask",
"RegionAttention",
"VisualizeBBoxesNode"
],
{
"title_aux": "ComfyUI-FluxRegionAttention"
}
],
"https://github.com/audioscavenger/ComfyUI-Thumbnails": [
[
"LoadImage"
@@ -11785,12 +11824,12 @@
"Bedrock - Amazon Nova Canvas Text to Image",
"Bedrock - Claude",
"Bedrock - Claude Multimodal",
"Bedrock - Luma AI Ray Video",
"Bedrock - Nova",
"Bedrock - Nova Background Prompt Replace",
"Bedrock - Nova IpAdapter",
"Bedrock - Nova Reel Video",
"Bedrock - Nova Text to Image",
"Bedrock - Nova Video",
"Bedrock - Ray2 Video",
"Bedrock - SDXL",
"Bedrock - Titan Inpainting",
"Bedrock - Titan Outpainting",
@@ -12141,6 +12180,7 @@
],
"https://github.com/billwuhao/ComfyUI_OneButtonPrompt_Flux": [
[
"DeepseekRun",
"OneButtonPromptFlux"
],
{
@@ -12708,7 +12748,8 @@
"LoaderGGUF",
"LoaderGGUFAdvanced",
"TENSORCut",
"TripleClipLoaderGGUF"
"TripleClipLoaderGGUF",
"VaeGGUF"
],
{
"preemptions": [
@@ -14227,6 +14268,7 @@
"LoadAudio",
"LoadImage",
"LoadImageMask",
"LoadImageOutput",
"LoadLatent",
"LoraLoader",
"LoraLoaderModelOnly",
@@ -14301,6 +14343,7 @@
"SaveImage",
"SaveImageWebsocket",
"SaveLatent",
"SaveWEBM",
"SelfAttentionGuidance",
"SetFirstSigma",
"SetLatentNoiseMask",
@@ -19441,6 +19484,17 @@
"title_aux": "qq-nodes-comfyui"
}
],
"https://github.com/kevinmcmahondev/comfyui-kmcdev-image-filter-adjustments": [
[
"ImageBlankAlpha",
"ImageBlendMask",
"ImageFilterAdjustments",
"ImageMixColorByMask"
],
{
"title_aux": "KMCDev Nodes"
}
],
"https://github.com/kevinmcmahondev/comfyui-skin-tone-detector": [
[
"SkinToneDetector"
@@ -20905,8 +20959,10 @@
"ApplyPulidFlux",
"FixPulidFluxPatch",
"PulidFluxEvaClipLoader",
"PulidFluxFaceDetector",
"PulidFluxInsightFaceLoader",
"PulidFluxModelLoader"
"PulidFluxModelLoader",
"PulidFluxOptions"
],
{
"title_aux": "ComfyUI_PuLID_Flux_ll"
@@ -20951,6 +21007,7 @@
"ForEachOpen",
"GetImageBatchSize",
"GetValueFromJsonObj",
"IfElseForEmptyObject",
"ImageEqual",
"ImageToBase64",
"ImageToBase64Advanced",
@@ -22188,6 +22245,7 @@
"BatchProcessorTpl",
"CaptionExportTpl",
"CaptionGeneratorTpl",
"DebugModelNodeTpl",
"DebugNodeTpl",
"ExifMetadataExtractorTpl",
"Florence2NodeTpl",
@@ -28075,6 +28133,28 @@
"title_aux": "ComfyUI Local Save Node"
}
],
"https://github.com/yhayano-ponotech/comfyui-stability-ai-api": [
[
"Preview3DModel",
"Save3DModel",
"StabilityControlSketch",
"StabilityControlStructure",
"StabilityControlStyle",
"StabilityEdit",
"StabilityImageCore",
"StabilityImageSD3",
"StabilityImageToVideo",
"StabilityImageUltra",
"StabilityUpscaleConservative",
"StabilityUpscaleCreative",
"StabilityUpscaleFast",
"StableFast3D",
"StablePointAware3D"
],
{
"title_aux": "ComfyUI-Stability-AI-API"
}
],
"https://github.com/yichengup/ComfyUI-VideoBlender": [
[
"VideoBlendLayer",
@@ -29048,14 +29128,6 @@
"title_aux": "SDXL_sizing"
}
],
"https://raw.githubusercontent.com/Smuzzies/comfyui_chatbox_overlay/main/chatbox_overlay.py": [
[
"Chatbox Overlay"
],
{
"title_aux": "Chatbox Overlay node for ComfyUI"
}
],
"https://raw.githubusercontent.com/barckley75/comfyUI_DaVinciResolve/main/custom_nodes/node_text_to_speech.py": [
[
"TextToSpeech"

View File

@@ -154,14 +154,27 @@ def switch_to_default_branch(repo):
repo.git.checkout(default_branch)
return True
except:
# try checkout master
# try checkout main if failed
try:
repo.git.checkout(repo.heads.master)
return True
except:
try:
if remote_name is not None:
repo.git.checkout('-b', 'master', f'{remote_name}/master')
return True
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")
return False

View File

File diff suppressed because it is too large Load Diff

View File

@@ -40,7 +40,8 @@ def git_url(fullpath):
if not os.path.exists(git_config_path):
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)
for k, v in config.items():
@@ -53,7 +54,14 @@ def git_url(fullpath):
def normalize_url(url) -> str:
if 'github' in url or (GITHUB_ENDPOINT is not None and GITHUB_ENDPOINT in url):
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]
url = f"https://github.com/{author}/{repo_name}"
return url

View File

@@ -42,7 +42,7 @@ import manager_downloader
from node_package import InstalledNodePackage
version_code = [3, 24, 1]
version_code = [3, 25, 1]
version_str = f"V{version_code[0]}.{version_code[1]}" + (f'.{version_code[2]}' if len(version_code) > 2 else '')
@@ -538,6 +538,8 @@ class UnifiedManager:
if node_package.is_disabled and node_package.is_unknown:
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)
if node_package.is_disabled and node_package.is_nightly:
@@ -548,6 +550,8 @@ class UnifiedManager:
if node_package.is_enabled and node_package.is_unknown:
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)
if node_package.is_from_cnr and node_package.is_disabled:
@@ -1059,8 +1063,8 @@ class UnifiedManager:
# update cache
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]
self.unknown_active_nodes[node_id] = to_path
return result.with_target(to_path)
elif version_spec == 'nightly':
del self.nightly_inactive_nodes[node_id]
@@ -1401,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)
if res.result:
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':
cnr_utils.generate_cnr_id(to_path, node_id)
self.active_nodes[node_id] = 'nightly', to_path
@@ -1566,7 +1570,7 @@ manager_funcs = ManagerFuncs()
def write_config():
config = configparser.ConfigParser()
config = configparser.ConfigParser(strict=False)
config['default'] = {
'preview_method': manager_funcs.get_current_preview_method(),
@@ -1577,6 +1581,7 @@ def write_config():
'bypass_ssl': get_config()['bypass_ssl'],
"file_logging": get_config()['file_logging'],
'component_policy': get_config()['component_policy'],
'update_policy': get_config()['update_policy'],
'windows_selector_event_loop_policy': get_config()['windows_selector_event_loop_policy'],
'model_download_by_agent': get_config()['model_download_by_agent'],
'downgrade_blacklist': get_config()['downgrade_blacklist'],
@@ -1596,7 +1601,7 @@ def write_config():
def read_config():
try:
config = configparser.ConfigParser()
config = configparser.ConfigParser(strict=False)
config.read(manager_config_path)
default_conf = config['default']
manager_util.use_uv = default_conf['use_uv'].lower() == 'true' if 'use_uv' in default_conf else False
@@ -1615,6 +1620,7 @@ def read_config():
'bypass_ssl': get_bool('bypass_ssl', False),
'file_logging': get_bool('file_logging', True),
'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),
'model_download_by_agent': get_bool('model_download_by_agent', False),
'downgrade_blacklist': default_conf.get('downgrade_blacklist', '').lower(),
@@ -1637,6 +1643,7 @@ def read_config():
'bypass_ssl': False,
'file_logging': True,
'component_policy': 'workflow',
'update_policy': 'stable-comfyui',
'windows_selector_event_loop_policy': False,
'model_download_by_agent': False,
'downgrade_blacklist': '',
@@ -1688,14 +1695,27 @@ def switch_to_default_branch(repo):
repo.git.checkout(default_branch)
return True
except:
# try checkout master
# try checkout main if failed
try:
repo.git.checkout(repo.heads.master)
return True
except:
try:
if remote_name is not None:
repo.git.checkout('-b', 'master', f'{remote_name}/master')
return True
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")
return False
@@ -2347,6 +2367,32 @@ def gitclone_update(files, instant_execution=False, skip_script=False, msg_prefi
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):
if not os.path.exists(os.path.join(repo_path, '.git')):
return "fail"
@@ -2354,9 +2400,12 @@ def update_path(repo_path, instant_execution=False, no_deps=False):
# version check
repo = git.Repo(repo_path)
is_switched = False
if repo.head.is_detached:
if not switch_to_default_branch(repo):
return "fail"
else:
is_switched = True
current_branch = repo.active_branch
branch_name = current_branch.name
@@ -2395,6 +2444,8 @@ def update_path(repo_path, instant_execution=False, no_deps=False):
git_pull(repo_path)
execute_install_script("ComfyUI", repo_path, instant_execution=instant_execution, no_deps=no_deps)
return "updated"
elif is_switched:
return "updated"
else:
return "skipped"
@@ -2705,9 +2756,6 @@ async def extract_nodes_from_workflow(filepath, mode='local', channel_url='defau
if ext == 'https://github.com/comfyanonymous/ComfyUI':
pass
elif ext is not None:
if 'Fooocus' in ext:
print(f">> {node_name}")
used_exts.add(ext)
else:
unknown_nodes.add(node_name)
@@ -3176,17 +3224,26 @@ async def check_need_to_migrate():
need_to_migrate = True
def get_comfyui_versions():
repo = git.Repo(comfy_path)
versions = [x.name for x in repo.tags if x.name.startswith('v')]
versions.reverse() # nearest tag
def get_comfyui_versions(repo=None):
if repo is None:
repo = git.Repo(comfy_path)
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]
current_tag = repo.git.describe('--tags')
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]
main_branch = repo.heads.master
@@ -3199,16 +3256,16 @@ def get_comfyui_versions():
versions[0] = 'nightly'
current_tag = 'nightly'
return versions, current_tag
return versions, current_tag, latest_tag
def switch_comfyui(tag):
repo = git.Repo(comfy_path)
if tag == 'nightly':
repo.git.checkout('main')
repo.git.checkout('master')
repo.remotes.origin.pull()
print("[ComfyUI-Manager] ComfyUI version is switched to the latest 'main' version")
print("[ComfyUI-Manager] ComfyUI version is switched to the latest 'master' version")
else:
repo.git.checkout(tag)
print(f"[ComfyUI-Manager] ComfyUI version is switched to '{tag}'")
@@ -3223,7 +3280,7 @@ def resolve_giturl_from_path(fullpath):
if not os.path.exists(git_config_path):
return "unknown"
config = configparser.ConfigParser()
config = configparser.ConfigParser(strict=False)
config.read(git_config_path)
for k, v in config.items():

View File

@@ -187,6 +187,8 @@ set_preview_method(core.get_config()['preview_method'])
def set_component_policy(mode):
core.get_config()['component_policy'] = mode
def set_update_policy(mode):
core.get_config()['update_policy'] = mode
def print_comfyui_version():
global comfy_ui_hash
@@ -452,20 +454,29 @@ async def task_worker():
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:
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":
logging.error("ComfyUI update fail: The installed ComfyUI does not have a Git repository.")
return "The installed ComfyUI does not have a Git repository."
elif res == "updated":
logging.info("ComfyUI is updated.")
return "success"
if is_stable:
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
logging.info("ComfyUI is up-to-date.")
return "skip"
except Exception:
traceback.print_exc()
@@ -597,7 +608,7 @@ async def task_worker():
elif kind == 'update-main':
msg = await do_update(item)
elif kind == 'update-comfyui':
msg = await do_update_comfyui()
msg = await do_update_comfyui(item[1])
elif kind == 'fix':
msg = await do_fix(item)
elif kind == 'uninstall':
@@ -1337,14 +1348,15 @@ async def update_custom_node(request):
@routes.get("/manager/queue/update_comfyui")
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)
@routes.get("/comfyui_manager/comfyui_versions")
async def comfyui_versions(request):
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')
except Exception as e:
logging.error(f"ComfyUI update fail: {e}", file=sys.stderr)
@@ -1435,7 +1447,7 @@ async def preview_method(request):
return web.Response(status=200)
@routes.get("/manager/component/policy")
@routes.get("/manager/policy/component")
async def component_policy(request):
if "value" in request.rel_url.query:
set_component_policy(request.rel_url.query['value'])
@@ -1446,6 +1458,17 @@ async def component_policy(request):
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")
async def channel_url_list(request):
channels = core.get_channel_dict()

View File

@@ -230,7 +230,7 @@ var update_all_button = null;
var restart_stop_button = null;
let share_option = 'all';
var is_updating_all = false;
var is_updating = false;
// copied style from https://github.com/pythongosssss/ComfyUI-Custom-Scripts
@@ -477,6 +477,8 @@ async function updateComfyUI() {
const response = await api.fetchApi('/manager/queue/update_comfyui');
showTerminal();
is_updating = true;
await api.fetchApi('/manager/queue/start');
}
@@ -605,8 +607,14 @@ function showVersionSelectorDialog(versions, current, onSelect) {
}
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" });
switch_comfyui_button.disabled = false;
switch_comfyui_button.style.backgroundColor = "";
if(res.status == 200) {
let obj = await res.json();
@@ -694,11 +702,11 @@ async function onQueueStatus(event) {
else if(event.detail.status == 'done') {
reset_action_buttons();
if(!is_updating_all) {
if(!is_updating) {
return;
}
is_updating_all = false;
is_updating = false;
let success_list = [];
let failed_list = [];
@@ -721,19 +729,25 @@ async function onQueueStatus(event) {
let msg = "";
if(success_list.length == 0 && comfyui_state != 'success') {
if(success_list.length == 0 && !comfyui_state.startsWith('success')) {
if(failed_list.length == 0) {
msg += "All custom nodes are already up to date.";
msg += "You are already up to date.";
}
}
else {
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') {
msg += "ComfyUI is updated.<BR><BR>";
if(comfyui_state == 'success-nightly') {
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') {
msg += "ComfyUI is already up-to-date.<BR><BR>"
msg += "ComfyUI is already up to date.<BR><BR>"
}
else if(comfyui_state != null) {
msg += "Failed to update ComfyUI.<BR><BR>"
@@ -811,7 +825,7 @@ async function updateAll(update_comfyui, manager_dialog) {
customAlert('Another task is already in progress. Please stop the ongoing task first.');
}
else if(response.status == 200) {
is_updating_all = true;
is_updating = true;
await api.fetchApi('/manager/queue/start');
}
}
@@ -995,6 +1009,8 @@ class ManagerMenuDialog extends ComfyDialog {
}
createControlsLeft() {
const isElectron = 'electronAPI' in window;
let self = this;
this.update_check_checkbox = $el("input",{type:'checkbox', id:"skip_update_check"},[])
@@ -1073,25 +1089,6 @@ class ManagerMenuDialog extends ComfyDialog {
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')
.then(response => response.text())
.then(data => {
@@ -1111,6 +1108,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);
});
let 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: Stable ComfyUI' }, []));
update_policy_combo.appendChild($el('option', { value: 'nightly-comfyui', text: 'Update: Nightly ComfyUI' }, []));
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 [
$el("div", {}, [this.update_check_checkbox, uc_checkbox_text]),
$el("br", {}, []),
@@ -1119,6 +1153,7 @@ class ManagerMenuDialog extends ComfyDialog {
preview_combo,
share_combo,
component_policy_combo,
update_policy_combo,
$el("br", {}, []),
$el("br", {}, []),
@@ -1145,11 +1180,6 @@ class ManagerMenuDialog extends ComfyDialog {
install_pip(url, self);
}
}
}),
$el("button.cm-experimental-button", {
type: "button",
textContent: "Unload models",
onclick: () => { free_models(); }
})
]),
];

View File

@@ -709,7 +709,7 @@ app.handleFile = handleFile;
let current_component_policy = 'workflow';
try {
api.fetchApi('/manager/component/policy')
api.fetchApi('/manager/policy/component')
.then(response => response.text())
.then(data => { current_component_policy = data; });
}

View File

@@ -4685,6 +4685,28 @@
"filename": "<huggingface>",
"url": "deepseek-ai/Janus-Pro-7B",
"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"
}
]
}

View File

@@ -14,6 +14,37 @@
{
"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]",
@@ -84,16 +115,6 @@
"install_type": "git-clone",
"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",
"title": "ComfyUI-VideoStream",
@@ -1742,16 +1763,6 @@
"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)"
},
{
"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",
"title": "ComfyUI-SkipCFGSigmas",

View File

@@ -370,6 +370,15 @@
"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": [
[
"ImageWithPrompt",
@@ -1325,6 +1334,37 @@
"title_aux": "ComfyUI-APG_ImYourCFGNow"
}
],
"https://github.com/NEZHA625/ComfyUI-tools-by-dong": [
[
"A1111_FLUX_DATA_NODE",
"CategorizeNode",
"FileMoveNode",
"FolderIteratorNODE",
"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": [
[
"North_Unsampler"
@@ -1443,14 +1483,6 @@
"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": [
[
"AreaCalculator",
@@ -1964,20 +1996,6 @@
"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": [
[
"ImageToPrompt",
@@ -2487,6 +2505,7 @@
"LoadAudio",
"LoadImage",
"LoadImageMask",
"LoadImageOutput",
"LoadLatent",
"LoraLoader",
"LoraLoaderModelOnly",
@@ -2561,6 +2580,7 @@
"SaveImage",
"SaveImageWebsocket",
"SaveLatent",
"SaveWEBM",
"SelfAttentionGuidance",
"SetFirstSigma",
"SetLatentNoiseMask",
@@ -3672,6 +3692,7 @@
"DownloadAndLoadHy3DDelightModel",
"DownloadAndLoadHy3DPaintModel",
"Hy3DApplyTexture",
"Hy3DBPT",
"Hy3DBakeFromMultiview",
"Hy3DCameraConfig",
"Hy3DDelightImage",
@@ -4015,6 +4036,7 @@
"HYCreateRegionalCond",
"HYFetaEnhance",
"HYFlowEditGuider",
"HYFlowEditGuiderCFG",
"HYFlowEditSampler",
"HYForwardODESampler",
"HYInverseModelSamplingPred",
@@ -4535,7 +4557,6 @@
],
"https://github.com/owengillett/ComfyUI-tilefusion": [
[
"RepeatVideo",
"VideoGridCombine"
],
{

View File

File diff suppressed because it is too large Load Diff

View File

@@ -11,6 +11,67 @@
{
"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",
@@ -629,69 +690,6 @@
],
"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."
}
]
}

View File

@@ -58,6 +58,7 @@
],
"https://github.com/1038lab/ComfyUI-RMBG": [
[
"BiRefNet",
"ClothesSegment",
"FaceSegment",
"FashionSegmentAccessories",
@@ -1381,6 +1382,12 @@
"Faishme Load Image from Glob",
"Faishme Mannequin to Model Loader",
"Faishme Moondream",
"Faishme Repeat Image Batch",
"Faishme Repeat Latent Batch",
"Faishme Stack Images",
"Faishme Stack Latents",
"Faishme Unstack Images",
"Faishme Unstack Latents",
"Load Fashion Model"
],
{
@@ -4187,6 +4194,15 @@
"title_aux": "ComfyUI-FilePathCreator"
}
],
"https://github.com/HJH-AILab/ComfyUI_StableAnimator": [
[
"StableAnimatorModels",
"StableAnimatorNode"
],
{
"title_aux": "ComfyUI_StableAnimator"
}
],
"https://github.com/HM-RunningHub/ComfyUI_RH_APICall": [
[
"RH_BatchImages",
@@ -7447,6 +7463,14 @@
"title_aux": "Panoramic Image Stitcher"
}
],
"https://github.com/RodrigoSKohl/StableDesign-for-ComfyUI": [
[
"interior-design-for-comfyui"
],
{
"title_aux": "Interior Design for Comfyui"
}
],
"https://github.com/RodrigoSKohl/comfyui-tryoff-anyone": [
[
"TryOffAnyoneNode"
@@ -8134,7 +8158,8 @@
],
"https://github.com/ShinChven/sc-comfy-nodes": [
[
"Rescale Node"
"Rescale Node",
"Width & Height"
],
{
"title_aux": "ShinChven's Custom Nodes Package"
@@ -11717,6 +11742,20 @@
"title_aux": "Core ML Suite for ComfyUI"
}
],
"https://github.com/attashe/ComfyUI-FluxRegionAttention": [
[
"BBoxToMaskNode",
"BoundingBoxNode",
"CLIPDebug",
"FluxRegionBBOX",
"FluxRegionMask",
"RegionAttention",
"VisualizeBBoxesNode"
],
{
"title_aux": "ComfyUI-FluxRegionAttention"
}
],
"https://github.com/audioscavenger/ComfyUI-Thumbnails": [
[
"LoadImage"
@@ -11785,12 +11824,12 @@
"Bedrock - Amazon Nova Canvas Text to Image",
"Bedrock - Claude",
"Bedrock - Claude Multimodal",
"Bedrock - Luma AI Ray Video",
"Bedrock - Nova",
"Bedrock - Nova Background Prompt Replace",
"Bedrock - Nova IpAdapter",
"Bedrock - Nova Reel Video",
"Bedrock - Nova Text to Image",
"Bedrock - Nova Video",
"Bedrock - Ray2 Video",
"Bedrock - SDXL",
"Bedrock - Titan Inpainting",
"Bedrock - Titan Outpainting",
@@ -12141,6 +12180,7 @@
],
"https://github.com/billwuhao/ComfyUI_OneButtonPrompt_Flux": [
[
"DeepseekRun",
"OneButtonPromptFlux"
],
{
@@ -12708,7 +12748,8 @@
"LoaderGGUF",
"LoaderGGUFAdvanced",
"TENSORCut",
"TripleClipLoaderGGUF"
"TripleClipLoaderGGUF",
"VaeGGUF"
],
{
"preemptions": [
@@ -14227,6 +14268,7 @@
"LoadAudio",
"LoadImage",
"LoadImageMask",
"LoadImageOutput",
"LoadLatent",
"LoraLoader",
"LoraLoaderModelOnly",
@@ -14301,6 +14343,7 @@
"SaveImage",
"SaveImageWebsocket",
"SaveLatent",
"SaveWEBM",
"SelfAttentionGuidance",
"SetFirstSigma",
"SetLatentNoiseMask",
@@ -19441,6 +19484,17 @@
"title_aux": "qq-nodes-comfyui"
}
],
"https://github.com/kevinmcmahondev/comfyui-kmcdev-image-filter-adjustments": [
[
"ImageBlankAlpha",
"ImageBlendMask",
"ImageFilterAdjustments",
"ImageMixColorByMask"
],
{
"title_aux": "KMCDev Nodes"
}
],
"https://github.com/kevinmcmahondev/comfyui-skin-tone-detector": [
[
"SkinToneDetector"
@@ -20905,8 +20959,10 @@
"ApplyPulidFlux",
"FixPulidFluxPatch",
"PulidFluxEvaClipLoader",
"PulidFluxFaceDetector",
"PulidFluxInsightFaceLoader",
"PulidFluxModelLoader"
"PulidFluxModelLoader",
"PulidFluxOptions"
],
{
"title_aux": "ComfyUI_PuLID_Flux_ll"
@@ -20951,6 +21007,7 @@
"ForEachOpen",
"GetImageBatchSize",
"GetValueFromJsonObj",
"IfElseForEmptyObject",
"ImageEqual",
"ImageToBase64",
"ImageToBase64Advanced",
@@ -22188,6 +22245,7 @@
"BatchProcessorTpl",
"CaptionExportTpl",
"CaptionGeneratorTpl",
"DebugModelNodeTpl",
"DebugNodeTpl",
"ExifMetadataExtractorTpl",
"Florence2NodeTpl",
@@ -28075,6 +28133,28 @@
"title_aux": "ComfyUI Local Save Node"
}
],
"https://github.com/yhayano-ponotech/comfyui-stability-ai-api": [
[
"Preview3DModel",
"Save3DModel",
"StabilityControlSketch",
"StabilityControlStructure",
"StabilityControlStyle",
"StabilityEdit",
"StabilityImageCore",
"StabilityImageSD3",
"StabilityImageToVideo",
"StabilityImageUltra",
"StabilityUpscaleConservative",
"StabilityUpscaleCreative",
"StabilityUpscaleFast",
"StableFast3D",
"StablePointAware3D"
],
{
"title_aux": "ComfyUI-Stability-AI-API"
}
],
"https://github.com/yichengup/ComfyUI-VideoBlender": [
[
"VideoBlendLayer",
@@ -29048,14 +29128,6 @@
"title_aux": "SDXL_sizing"
}
],
"https://raw.githubusercontent.com/Smuzzies/comfyui_chatbox_overlay/main/chatbox_overlay.py": [
[
"Chatbox Overlay"
],
{
"title_aux": "Chatbox Overlay node for ComfyUI"
}
],
"https://raw.githubusercontent.com/barckley75/comfyUI_DaVinciResolve/main/custom_nodes/node_text_to_speech.py": [
[
"TextToSpeech"

View File

@@ -1,5 +1,28 @@
{
"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",
"type": "Janus-Pro",

View File

@@ -301,6 +301,16 @@
],
"install_type": "git-clone",
"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"
}
]
}

View File

@@ -95,7 +95,7 @@ def read_config():
global default_conf
try:
import configparser
config = configparser.ConfigParser()
config = configparser.ConfigParser(strict=False)
config.read(manager_config_path)
default_conf = config['default']
except Exception:
@@ -787,7 +787,7 @@ if script_executed:
def check_windows_event_loop_policy():
try:
import configparser
config = configparser.ConfigParser()
config = configparser.ConfigParser(strict=False)
config.read(manager_config_path)
default_conf = config['default']

View File

@@ -1,7 +1,7 @@
[project]
name = "comfyui-manager"
description = "ComfyUI-Manager provides features to install and manage custom nodes for ComfyUI, as well as various functionalities to assist with ComfyUI."
version = "3.24.1"
version = "3.25.1"
license = { file = "LICENSE.txt" }
dependencies = ["GitPython", "PyGithub", "matrix-client==0.4.0", "transformers", "huggingface-hub>0.20", "typer", "rich", "typing-extensions"]