Create start.sh
Browse files
start.sh
ADDED
|
@@ -0,0 +1,60 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
#!/usr/bin/env bash
|
| 2 |
+
|
| 3 |
+
SCRIPT_DIR=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )
|
| 4 |
+
cd "$SCRIPT_DIR" || exit
|
| 5 |
+
|
| 6 |
+
KEY_FILE=.webui_secret_key
|
| 7 |
+
|
| 8 |
+
PORT="${PORT:-8080}"
|
| 9 |
+
HOST="${HOST:-0.0.0.0}"
|
| 10 |
+
if test "$WEBUI_SECRET_KEY $WEBUI_JWT_SECRET_KEY" = " "; then
|
| 11 |
+
echo "Loading WEBUI_SECRET_KEY from file, not provided as an environment variable."
|
| 12 |
+
|
| 13 |
+
if ! [ -e "$KEY_FILE" ]; then
|
| 14 |
+
echo "Generating WEBUI_SECRET_KEY"
|
| 15 |
+
# Generate a random value to use as a WEBUI_SECRET_KEY in case the user didn't provide one.
|
| 16 |
+
echo $(head -c 12 /dev/random | base64) > "$KEY_FILE"
|
| 17 |
+
fi
|
| 18 |
+
|
| 19 |
+
echo "Loading WEBUI_SECRET_KEY from $KEY_FILE"
|
| 20 |
+
WEBUI_SECRET_KEY=$(cat "$KEY_FILE")
|
| 21 |
+
fi
|
| 22 |
+
|
| 23 |
+
if [[ "${USE_OLLAMA_DOCKER,,}" == "true" ]]; then
|
| 24 |
+
echo "USE_OLLAMA is set to true, starting ollama serve."
|
| 25 |
+
ollama serve &
|
| 26 |
+
fi
|
| 27 |
+
|
| 28 |
+
if [[ "${USE_CUDA_DOCKER,,}" == "true" ]]; then
|
| 29 |
+
echo "CUDA is enabled, appending LD_LIBRARY_PATH to include torch/cudnn & cublas libraries."
|
| 30 |
+
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"
|
| 31 |
+
fi
|
| 32 |
+
|
| 33 |
+
# Start cron daemon
|
| 34 |
+
service cron start
|
| 35 |
+
|
| 36 |
+
# Check if SPACE_ID is set, if so, configure for space
|
| 37 |
+
if [ -n "$SPACE_ID" ]; then
|
| 38 |
+
echo "Configuring for HuggingFace Space deployment"
|
| 39 |
+
if [ -n "$ADMIN_USER_EMAIL" ] && [ -n "$ADMIN_USER_PASSWORD" ]; then
|
| 40 |
+
echo "Admin user configured, creating"
|
| 41 |
+
WEBUI_SECRET_KEY="$WEBUI_SECRET_KEY" uvicorn main:app --host "$HOST" --port "$PORT" --forwarded-allow-ips '*' &
|
| 42 |
+
webui_pid=$!
|
| 43 |
+
echo "Waiting for webui to start..."
|
| 44 |
+
while ! curl -s http://localhost:8080/health > /dev/null; do
|
| 45 |
+
sleep 1
|
| 46 |
+
done
|
| 47 |
+
echo "Creating admin user..."
|
| 48 |
+
curl \
|
| 49 |
+
-X POST "http://localhost:8080/api/v1/auths/signup" \
|
| 50 |
+
-H "accept: application/json" \
|
| 51 |
+
-H "Content-Type: application/json" \
|
| 52 |
+
-d "{ \"email\": \"${ADMIN_USER_EMAIL}\", \"password\": \"${ADMIN_USER_PASSWORD}\", \"name\": \"Admin\" }"
|
| 53 |
+
echo "Shutting down webui..."
|
| 54 |
+
kill $webui_pid
|
| 55 |
+
fi
|
| 56 |
+
|
| 57 |
+
export WEBUI_URL=${SPACE_HOST}
|
| 58 |
+
fi
|
| 59 |
+
|
| 60 |
+
WEBUI_SECRET_KEY="$WEBUI_SECRET_KEY" exec uvicorn main:app --host "$HOST" --port "$PORT" --forwarded-allow-ips '*'
|