mirror of
https://github.com/ajnart/homarr.git
synced 2026-01-29 10:49:14 +01:00
45 lines
1.2 KiB
Bash
45 lines
1.2 KiB
Bash
# Creating folders in volume
|
|
mkdir -p /appdata/db
|
|
mkdir -p /appdata/redis
|
|
|
|
# Run migrations
|
|
if [ $DB_MIGRATIONS_DISABLED = "true" ]; then
|
|
echo "DB migrations are disabled, skipping"
|
|
else
|
|
echo "Running DB migrations"
|
|
node ./db/migrations/$DB_DIALECT/migrate.cjs ./db/migrations/$DB_DIALECT
|
|
fi
|
|
|
|
# Generates an encryption key if it doesn't exist and saves it to /secrets/encryptionKey
|
|
# Also sets the ENCRYPTION_KEY environment variable
|
|
encryptionKey=""
|
|
if [ -r /secrets/encryptionKey ]; then
|
|
echo "Encryption key already exists"
|
|
encryptionKey=$(cat /secrets/encryptionKey)
|
|
else
|
|
echo "Generating encryption key"
|
|
encryptionKey=$(node ./generateEncryptionKey.js)
|
|
echo $encryptionKey > /secrets/encryptionKey
|
|
fi
|
|
export ENCRYPTION_KEY=$encryptionKey
|
|
|
|
# Start nginx proxy
|
|
# 1. Replace the HOSTNAME in the nginx template file
|
|
# 2. Create the nginx configuration file from the template
|
|
# 3. Start the nginx server
|
|
envsubst '${HOSTNAME}' < /etc/nginx/templates/nginx.conf > /etc/nginx/nginx.conf
|
|
nginx -g 'daemon off;' &
|
|
|
|
# Start Redis
|
|
redis-server /app/redis.conf &
|
|
|
|
# Run the tasks backend
|
|
node apps/tasks/tasks.cjs &
|
|
|
|
node apps/websocket/wssServer.cjs &
|
|
|
|
# Run the nextjs server
|
|
node apps/nextjs/server.js & PID=$!
|
|
|
|
wait $PID
|