#!/bin/bash # This file will be sourced in init.sh # https://raw.githubusercontent.com/ai-dock/comfyui/main/config/provisioning/default.sh # Packages are installed after nodes so we can fix them... DEFAULT_WORKFLOW="https://comfyanonymous.github.io/ComfyUI_examples/cosmos/text_to_video_cosmos_7B.json" APT_PACKAGES=( #"package-1" #"package-2" ) PIP_PACKAGES=( #"package-1" #"package-2" ) NODES=( "https://github.com/ltdrdata/ComfyUI-Manager" "https://github.com/cubiq/ComfyUI_essentials" ) CHECKPOINT_MODELS=( ) CLIP_MODELS=( ) DIFFUSION_MODELS=( #"https://huggingface.co/mcmonkey/cosmos-1.0/resolve/main/Cosmos-1_0-Diffusion-14B-Text2World.safetensors" #"https://huggingface.co/mcmonkey/cosmos-1.0/resolve/main/Cosmos-1_0-Diffusion-14B-Video2World.safetensors" "https://huggingface.co/mcmonkey/cosmos-1.0/resolve/main/Cosmos-1_0-Diffusion-7B-Text2World.safetensors" "https://huggingface.co/mcmonkey/cosmos-1.0/resolve/main/Cosmos-1_0-Diffusion-7B-Video2World.safetensors" ) UNET_MODELS=( ) LORA_MODELS=( #"https://civitai.com/api/download/models/16576" ) VAE_MODELS=( "https://huggingface.co/comfyanonymous/cosmos_1.0_text_encoder_and_VAE_ComfyUI/blob/main/vae/cosmos_cv8x8x8_1.0.safetensors" ) ESRGAN_MODELS=( ) CONTROLNET_MODELS=( ) TEXT_ENCODERS=( "https://huggingface.co/quarterturn/comfyui-cosmos-files/resolve/main/oldt5_xxl_fp16.safetensors" "https://huggingface.co/quarterturn/comfyui-cosmos-files/resolve/main/oldt5_xxl_fp8_e4m3fn_scaled.safetensors" ) ### DO NOT EDIT BELOW HERE UNLESS YOU KNOW WHAT YOU ARE DOING ### function provisioning_start() { if [[ ! -d /opt/environments/python ]]; then export MAMBA_BASE=true fi source /opt/ai-dock/etc/environment.sh source /opt/ai-dock/bin/venv-set.sh comfyui provisioning_print_header provisioning_get_apt_packages provisioning_get_nodes provisioning_get_pip_packages provisioning_get_models \ "${WORKSPACE}/ComfyUI/models/ckpt" \ "${CHECKPOINT_MODELS[@]}" provisioning_get_models \ "${WORKSPACE}/ComfyUI/models/unet" \ "${UNET_MODELS[@]}" provisioning_get_models \ "${WORKSPACE}/ComfyUI/models/lora" \ "${LORA_MODELS[@]}" provisioning_get_models \ "${WORKSPACE}/ComfyUI/models/controlnet" \ "${CONTROLNET_MODELS[@]}" provisioning_get_models \ "${WORKSPACE}/ComfyUI/models/vae" \ "${VAE_MODELS[@]}" provisioning_get_models \ "${WORKSPACE}/ComfyUI/models/esrgan" \ "${ESRGAN_MODELS[@]}" provisioning_get_models \ "${WORKSPACE}/ComfyUI/models/text_encoders" \ "${TEXT_ENCODERS[@]}" provisioning_get_models \ "${WORKSPACE}/ComfyUI/models/diffusion_models" \ "${DIFFUSION_MODELS[@]}" provisioning_print_end } function pip_install() { if [[ -z $MAMBA_BASE ]]; then "$COMFYUI_VENV_PIP" install --no-cache-dir "$@" else micromamba run -n comfyui pip install --no-cache-dir "$@" fi } function provisioning_get_apt_packages() { if [[ -n $APT_PACKAGES ]]; then sudo $APT_INSTALL ${APT_PACKAGES[@]} fi } function provisioning_get_pip_packages() { if [[ -n $PIP_PACKAGES ]]; then pip_install ${PIP_PACKAGES[@]} fi } function provisioning_get_nodes() { for repo in "${NODES[@]}"; do dir="${repo##*/}" path="/opt/ComfyUI/custom_nodes/${dir}" requirements="${path}/requirements.txt" if [[ -d $path ]]; then if [[ ${AUTO_UPDATE,,} != "false" ]]; then printf "Updating node: %s...\n" "${repo}" ( cd "$path" && git pull ) if [[ -e $requirements ]]; then pip_install -r "$requirements" fi fi else printf "Downloading node: %s...\n" "${repo}" git clone "${repo}" "${path}" --recursive if [[ -e $requirements ]]; then pip_install -r "${requirements}" fi fi done } function provisioning_get_default_workflow() { if [[ -n $DEFAULT_WORKFLOW ]]; then workflow_json=$(curl -s "$DEFAULT_WORKFLOW") if [[ -n $workflow_json ]]; then echo "export const defaultGraph = $workflow_json;" > /opt/ComfyUI/web/scripts/defaultGraph.js fi fi } function provisioning_get_models() { if [[ -z $2 ]]; then return 1; fi dir="$1" mkdir -p "$dir" shift arr=("$@") printf "Downloading %s model(s) to %s...\n" "${#arr[@]}" "$dir" for url in "${arr[@]}"; do printf "Downloading: %s\n" "${url}" provisioning_download "${url}" "${dir}" printf "\n" done } function provisioning_print_header() { printf "\n##############################################\n# #\n# Provisioning container #\n# #\n# This will take some time #\n# #\n# Your container will be ready on completion #\n# #\n##############################################\n\n" if [[ $DISK_GB_ALLOCATED -lt $DISK_GB_REQUIRED ]]; then printf "WARNING: Your allocated disk size (%sGB) is below the recommended %sGB - Some models will not be downloaded\n" "$DISK_GB_ALLOCATED" "$DISK_GB_REQUIRED" fi } function provisioning_print_end() { printf "\nProvisioning complete: Web UI will start now\n\n" } function provisioning_has_valid_hf_token() { [[ -n "$HF_TOKEN" ]] || return 1 url="https://huggingface.co/api/whoami-v2" response=$(curl -o /dev/null -s -w "%{http_code}" -X GET "$url" \ -H "Authorization: Bearer $HF_TOKEN" \ -H "Content-Type: application/json") # Check if the token is valid if [ "$response" -eq 200 ]; then return 0 else return 1 fi } function provisioning_has_valid_civitai_token() { [[ -n "$CIVITAI_TOKEN" ]] || return 1 url="https://civitai.com/api/v1/models?hidden=1&limit=1" response=$(curl -o /dev/null -s -w "%{http_code}" -X GET "$url" \ -H "Authorization: Bearer $CIVITAI_TOKEN" \ -H "Content-Type: application/json") # Check if the token is valid if [ "$response" -eq 200 ]; then return 0 else return 1 fi } # Download from $1 URL to $2 file path function provisioning_download() { if [[ -n $HF_TOKEN && $1 =~ ^https://([a-zA-Z0-9_-]+\.)?huggingface\.co(/|$|\?) ]]; then auth_token="$HF_TOKEN" elif [[ -n $CIVITAI_TOKEN && $1 =~ ^https://([a-zA-Z0-9_-]+\.)?civitai\.com(/|$|\?) ]]; then auth_token="$CIVITAI_TOKEN" fi if [[ -n $auth_token ]];then wget --header="Authorization: Bearer $auth_token" -qnc --content-disposition --show-progress -e dotbytes="${3:-4M}" -P "$2" "$1" else wget -qnc --content-disposition --show-progress -e dotbytes="${3:-4M}" -P "$2" "$1" fi } provisioning_start