Skip to content

Instantly share code, notes, and snippets.

@twinnedAI
Last active November 30, 2025 20:49
Show Gist options
  • Select an option

  • Save twinnedAI/4fdc7151a4c42f776ee0341b4ec76172 to your computer and use it in GitHub Desktop.

Select an option

Save twinnedAI/4fdc7151a4c42f776ee0341b4ec76172 to your computer and use it in GitHub Desktop.
#!/bin/bash
source /venv/main/bin/activate
COMFYUI_DIR=${WORKSPACE}/ComfyUI
# Packages are installed after nodes so we can fix them...
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"
"https://github.com/ssitu/ComfyUI_UltimateSDUpscale"
)
WORKFLOWS=(
)
CHECKPOINT_MODELS=(
"https://civitai.com/api/download/models/798204?type=Model&format=SafeTensor&size=full&fp=fp16"
)
UNET_MODELS=(
)
LORA_MODELS=(
)
VAE_MODELS=(
"https://huggingface.co/black-forest-labs/FLUX.1-dev/resolve/main/ae.safetensors"
)
TEXT_ENCODERS=(
"https://huggingface.co/Comfy-Org/z_image_turbo/resolve/main/split_files/text_encoders/qwen_3_4b.safetensors"
)
DIFFUSION_MODELS=(
"https://huggingface.co/Comfy-Org/z_image_turbo/resolve/main/split_files/diffusion_models/z_image_turbo_bf16.safetensors"
)
ESRGAN_MODELS=(
)
CONTROLNET_MODELS=(
)
### DO NOT EDIT BELOW HERE UNLESS YOU KNOW WHAT YOU ARE DOING ###
function provisioning_start() {
provisioning_print_header
provisioning_get_apt_packages
provisioning_get_nodes
provisioning_get_pip_packages
provisioning_get_files \
"${COMFYUI_DIR}/models/checkpoints" \
"${CHECKPOINT_MODELS[@]}"
provisioning_get_files \
"${COMFYUI_DIR}/models/unet" \
"${UNET_MODELS[@]}"
provisioning_get_files \
"${COMFYUI_DIR}/models/lora" \
"${LORA_MODELS[@]}"
provisioning_get_files \
"${COMFYUI_DIR}/models/controlnet" \
"${CONTROLNET_MODELS[@]}"
provisioning_get_files \
"${COMFYUI_DIR}/models/vae" \
"${VAE_MODELS[@]}"
provisioning_get_files \
"${COMFYUI_DIR}/models/esrgan" \
"${ESRGAN_MODELS[@]}"
# --- DEBUG START ---
echo "DEBUG: Inhalt von TEXT_ENCODERS:"
echo "${TEXT_ENCODERS[@]}"
echo "DEBUG: Anzahl Elemente: ${#TEXT_ENCODERS[@]}"
echo "DEBUG: Inhalt von DIFFUSION_MODELS:"
echo "${DIFFUSION_MODELS[@]}"
echo "DEBUG: Anzahl Elemente: ${#DIFFUSION_MODELS[@]}"
# --- DEBUG ENDE ---
provisioning_get_files \
"${COMFYUI_DIR}/models/diffusion_models" \
"${DIFFUSION_MODELS[@]}"
provisioning_get_files \
"${COMFYUI_DIR}/models/text_encoders" \
"${TEXT_ENCODERS[@]}"
provisioning_print_end
}
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 --no-cache-dir ${PIP_PACKAGES[@]}
fi
}
function provisioning_get_nodes() {
for repo in "${NODES[@]}"; do
dir="${repo##*/}"
path="${COMFYUI_DIR}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 --no-cache-dir -r "$requirements"
fi
fi
else
printf "Downloading node: %s...\n" "${repo}"
git clone "${repo}" "${path}" --recursive
if [[ -e $requirements ]]; then
pip install --no-cache-dir -r "${requirements}"
fi
fi
done
}
function provisioning_get_files() {
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"
}
function provisioning_print_end() {
printf "\nProvisioning complete: Application 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
}
# Allow user to disable provisioning if they started with a script they didn't want
if [[ ! -f /.noprovisioning ]]; then
provisioning_start
fi
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment