AppFlowy-Cloud/build/run_local_server.sh

58 lines
1.8 KiB
Bash
Executable File

#!/usr/bin/env bash
set -x
set -eo pipefail
cd "$(dirname "$0")/.."
DB_USER="${POSTGRES_USER:=postgres}"
DB_PASSWORD="${POSTGRES_PASSWORD:=password}"
DB_PORT="${POSTGRES_PORT:=5433}"
DB_HOST="${POSTGRES_HOST:=localhost}"
# Stop and remove any existing containers to avoid conflicts
docker-compose --file ./docker-compose-dev.yml down
# Start the Docker Compose setup
export GOTRUE_MAILER_AUTOCONFIRM=true
docker-compose --file ./docker-compose-dev.yml up -d --build
# Keep pinging Postgres until it's ready to accept commands
ATTEMPTS=0
MAX_ATTEMPTS=30 # Adjust this value based on your needs
until PGPASSWORD="${DB_PASSWORD}" psql -h "${DB_HOST}" -U "${DB_USER}" -p "${DB_PORT}" -d "postgres" -c '\q' || [ $ATTEMPTS -eq $MAX_ATTEMPTS ]; do
>&2 echo "Postgres is still unavailable - sleeping"
sleep 1
ATTEMPTS=$((ATTEMPTS+1))
done
if [ $ATTEMPTS -eq $MAX_ATTEMPTS ]; then
>&2 echo "Failed to connect to Postgres after $MAX_ATTEMPTS attempts, exiting."
exit 1
fi
until curl localhost:9998/health; do
>&2 echo "Waiting on GoTrue"
sleep 1
done
# Kill any existing instances
pkill -f appflowy_cloud || true
# Require if there are any changes to the database schema
# To build AppFlowy-Cloud binary, we requires the .sqlx files
# To generate the .sqlx files, we need to run the following command
# After the .sqlx files are generated, we build in SQLX_OFFLINE=true
# where we don't need to connect to the database
cargo sqlx database create && cargo sqlx migrate run && cargo sqlx prepare --workspace
RUST_LOG=trace cargo run &
# sometimes the gotrue server may not be ready yet
sleep 1
# created registered user
./build/init_registered_user.sh
# revert to require signup email verification
export GOTRUE_MAILER_AUTOCONFIRM=false
docker-compose --file ./docker-compose-dev.yml up -d