| | #!/usr/bin/env bash |
| |
|
| | SCRIPT_DIR=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd ) |
| | cd "$SCRIPT_DIR" || exit |
| |
|
| | |
| | if [[ "${WEB_LOADER_ENGINE,,}" == "playwright" ]]; then |
| | if [[ -z "${PLAYWRIGHT_WS_URL}" ]]; then |
| | echo "Installing Playwright browsers..." |
| | playwright install chromium |
| | playwright install-deps chromium |
| | fi |
| |
|
| | python -c "import nltk; nltk.download('punkt_tab')" |
| | fi |
| |
|
| | if [ -n "${WEBUI_SECRET_KEY_FILE}" ]; then |
| | KEY_FILE="${WEBUI_SECRET_KEY_FILE}" |
| | else |
| | KEY_FILE=".webui_secret_key" |
| | fi |
| |
|
| | PORT="${PORT:-8080}" |
| | HOST="${HOST:-0.0.0.0}" |
| | if test "$WEBUI_SECRET_KEY $WEBUI_JWT_SECRET_KEY" = " "; then |
| | echo "Loading WEBUI_SECRET_KEY from file, not provided as an environment variable." |
| |
|
| | if ! [ -e "$KEY_FILE" ]; then |
| | echo "Generating WEBUI_SECRET_KEY" |
| | |
| | echo $(head -c 12 /dev/random | base64) > "$KEY_FILE" |
| | fi |
| |
|
| | echo "Loading WEBUI_SECRET_KEY from $KEY_FILE" |
| | WEBUI_SECRET_KEY=$(cat "$KEY_FILE") |
| | fi |
| |
|
| | if [[ "${USE_OLLAMA_DOCKER,,}" == "true" ]]; then |
| | echo "USE_OLLAMA is set to true, starting ollama serve." |
| | ollama serve & |
| | fi |
| |
|
| | if [[ "${USE_CUDA_DOCKER,,}" == "true" ]]; then |
| | echo "CUDA is enabled, appending LD_LIBRARY_PATH to include torch/cudnn & cublas libraries." |
| | export LD_LIBRARY_PATH="$LD_LIBRARY_PATH:/usr/local/lib/python3.11/site-packages/torch/lib:/usr/local/lib/python3.11/site-packages/nvidia/cudnn/lib" |
| | fi |
| |
|
| | |
| | if [ -n "$SPACE_ID" ]; then |
| | echo "Configuring for HuggingFace Space deployment" |
| | if [ -n "$ADMIN_USER_EMAIL" ] && [ -n "$ADMIN_USER_PASSWORD" ]; then |
| | echo "Admin user configured, creating" |
| | WEBUI_SECRET_KEY="$WEBUI_SECRET_KEY" uvicorn open_webui.main:app --host "$HOST" --port "$PORT" --forwarded-allow-ips '*' & |
| | webui_pid=$! |
| | echo "Waiting for webui to start..." |
| | while ! curl -s "http://localhost:${PORT}/health" > /dev/null; do |
| | sleep 1 |
| | done |
| | echo "Creating admin user..." |
| | curl \ |
| | -X POST "http://localhost:${PORT}/api/v1/auths/signup" \ |
| | -H "accept: application/json" \ |
| | -H "Content-Type: application/json" \ |
| | -d "{ \"email\": \"${ADMIN_USER_EMAIL}\", \"password\": \"${ADMIN_USER_PASSWORD}\", \"name\": \"Admin\" }" |
| | echo "Shutting down webui..." |
| | kill $webui_pid |
| | fi |
| |
|
| | export WEBUI_URL=${SPACE_HOST} |
| | fi |
| |
|
| | PYTHON_CMD=$(command -v python3 || command -v python) |
| | UVICORN_WORKERS="${UVICORN_WORKERS:-1}" |
| |
|
| | |
| | if [ "$#" -gt 0 ]; then |
| | ARGS=("$@") |
| | else |
| | ARGS=(--workers "$UVICORN_WORKERS") |
| | fi |
| |
|
| | |
| | WEBUI_SECRET_KEY="$WEBUI_SECRET_KEY" exec "$PYTHON_CMD" -m uvicorn open_webui.main:app \ |
| | --host "$HOST" \ |
| | --port "$PORT" \ |
| | --forwarded-allow-ips '*' \ |
| | "${ARGS[@]}" |