Steps 6-9 renumbered to 7-10 to account for the port availability check step added earlier in the script.
180 lines
5.9 KiB
Bash
180 lines
5.9 KiB
Bash
#!/bin/bash
|
|
|
|
# Laravel Docker Development Template - Quick Setup
|
|
# Everything is pre-installed! This just starts Docker and sets up the database.
|
|
# Usage: ./setup.sh [mysql|pgsql|sqlite]
|
|
|
|
set -e
|
|
|
|
DB=${1:-mysql}
|
|
VALID_DBS=("mysql" "pgsql" "sqlite")
|
|
|
|
# Colors
|
|
GREEN='\033[0;32m'
|
|
YELLOW='\033[1;33m'
|
|
RED='\033[0;31m'
|
|
NC='\033[0m'
|
|
|
|
echo -e "${GREEN}╔════════════════════════════════════════════════════════╗${NC}"
|
|
echo -e "${GREEN}║ Laravel Docker Development Template ║${NC}"
|
|
echo -e "${GREEN}║ Quick Setup - Everything Pre-Installed! ║${NC}"
|
|
echo -e "${GREEN}╚════════════════════════════════════════════════════════╝${NC}"
|
|
echo ""
|
|
|
|
# Validate database choice
|
|
if [[ ! " ${VALID_DBS[@]} " =~ " ${DB} " ]]; then
|
|
echo -e "${RED}Error: Invalid database '${DB}'${NC}"
|
|
echo "Usage: ./setup.sh [mysql|pgsql|sqlite]"
|
|
echo "Example: ./setup.sh mysql"
|
|
exit 1
|
|
fi
|
|
|
|
echo -e "${YELLOW}Setting up with ${DB}...${NC}"
|
|
echo ""
|
|
|
|
# Step 1: Check port availability
|
|
echo -e "${YELLOW}→ Checking port availability...${NC}"
|
|
PORTS_OK=1
|
|
|
|
# Function to check if port is in use
|
|
check_port() {
|
|
local port=$1
|
|
local service=$2
|
|
if lsof -Pi :$port -sTCP:LISTEN -t >/dev/null 2>&1 || netstat -tuln 2>/dev/null | grep -q ":$port "; then
|
|
echo -e "${RED}[✗] Port $port ($service) - IN USE${NC}"
|
|
PORTS_OK=0
|
|
else
|
|
echo -e "${GREEN}[✓] Port $port ($service) - Available${NC}"
|
|
fi
|
|
}
|
|
|
|
# Check required ports
|
|
check_port 8080 "Web Server"
|
|
check_port 8025 "Mailpit Dashboard"
|
|
check_port 1025 "Mailpit SMTP"
|
|
check_port 6379 "Redis"
|
|
|
|
# Check database port based on selection
|
|
if [ "$DB" = "mysql" ]; then
|
|
check_port 3306 "MySQL"
|
|
elif [ "$DB" = "pgsql" ]; then
|
|
check_port 5432 "PostgreSQL"
|
|
fi
|
|
|
|
# Handle port conflicts
|
|
if [ $PORTS_OK -eq 0 ]; then
|
|
echo ""
|
|
echo -e "${RED}WARNING: Some required ports are already in use!${NC}"
|
|
echo ""
|
|
echo "To find what's using a port:"
|
|
echo " lsof -i :PORT"
|
|
echo " netstat -tuln | grep :PORT"
|
|
echo ""
|
|
echo "To stop a process using a port:"
|
|
echo " 1. Find the PID: lsof -ti :PORT"
|
|
echo " 2. Kill the process: kill -9 PID"
|
|
echo ""
|
|
read -p "Do you want to continue anyway? (y/N): " -n 1 -r
|
|
echo ""
|
|
if [[ ! $REPLY =~ ^[Yy]$ ]]; then
|
|
echo -e "${RED}Setup cancelled.${NC}"
|
|
exit 1
|
|
fi
|
|
echo ""
|
|
echo -e "${YELLOW}Continuing with setup...${NC}"
|
|
fi
|
|
echo ""
|
|
|
|
# Step 2: Configure environment
|
|
echo -e "${YELLOW}→ Configuring environment...${NC}"
|
|
if [ -f "src/.env.${DB}" ]; then
|
|
cp "src/.env.${DB}" "src/.env"
|
|
echo -e "${GREEN}✓ Environment configured for ${DB}${NC}"
|
|
else
|
|
echo -e "${RED}✗ Template file src/.env.${DB} not found${NC}"
|
|
exit 1
|
|
fi
|
|
|
|
# Step 3: Build containers
|
|
echo -e "${YELLOW}→ Building Docker containers...${NC}"
|
|
docker-compose build
|
|
echo -e "${GREEN}✓ Containers built${NC}"
|
|
echo ""
|
|
|
|
# Step 4: Start containers
|
|
echo -e "${YELLOW}→ Starting Docker containers...${NC}"
|
|
docker-compose --profile ${DB} up -d
|
|
echo -e "${GREEN}✓ Containers started${NC}"
|
|
echo ""
|
|
|
|
# Step 5: Wait for app container to be ready
|
|
echo -e "${YELLOW}→ Waiting for app container...${NC}"
|
|
sleep 3
|
|
echo -e "${GREEN}✓ App container ready${NC}"
|
|
echo ""
|
|
|
|
# Step 6: Wait for database
|
|
if [ "$DB" = "mysql" ] || [ "$DB" = "pgsql" ]; then
|
|
echo -e "${YELLOW}→ Waiting for database...${NC}"
|
|
sleep 5
|
|
echo -e "${GREEN}✓ Database ready${NC}"
|
|
echo ""
|
|
fi
|
|
|
|
# Step 7: Generate app key
|
|
echo -e "${YELLOW}→ Generating application key...${NC}"
|
|
docker-compose exec app php artisan key:generate --force
|
|
echo -e "${GREEN}✓ App key generated${NC}"
|
|
echo ""
|
|
|
|
# Step 8: Run migrations
|
|
echo -e "${YELLOW}→ Running database migrations...${NC}"
|
|
docker-compose exec app php artisan migrate --force
|
|
echo -e "${GREEN}✓ Migrations completed${NC}"
|
|
echo ""
|
|
|
|
# Step 9: Seed database (roles, permissions, admin user)
|
|
echo -e "${YELLOW}→ Seeding database (roles, permissions, admin user)...${NC}"
|
|
docker-compose exec app php artisan db:seed --force
|
|
echo -e "${GREEN}✓ Database seeded${NC}"
|
|
echo ""
|
|
|
|
# Step 10: Create storage link
|
|
echo -e "${YELLOW}→ Creating storage symlink...${NC}"
|
|
docker-compose exec app php artisan storage:link
|
|
echo -e "${GREEN}✓ Storage linked${NC}"
|
|
echo ""
|
|
|
|
# Done!
|
|
echo ""
|
|
echo -e "${GREEN}╔════════════════════════════════════════════════════════╗${NC}"
|
|
echo -e "${GREEN}║ 🎉 Setup Complete! 🎉 ║${NC}"
|
|
echo -e "${GREEN}╚════════════════════════════════════════════════════════╝${NC}"
|
|
echo ""
|
|
echo -e "${GREEN}Your Laravel application is ready!${NC}"
|
|
echo ""
|
|
echo -e " 📱 Laravel App: ${GREEN}http://localhost:8080${NC}"
|
|
echo -e " 🔐 Admin Panel: ${GREEN}http://localhost:8080/admin${NC}"
|
|
echo -e " 📧 Mailpit: ${GREEN}http://localhost:8025${NC}"
|
|
echo ""
|
|
echo -e "${YELLOW}Admin Login:${NC}"
|
|
echo -e " Email: admin@example.com"
|
|
echo -e " Password: password"
|
|
echo ""
|
|
echo -e "${YELLOW}What's Included:${NC}"
|
|
echo -e " ✓ Laravel 11 with Breeze authentication"
|
|
echo -e " ✓ Filament admin panel with user management"
|
|
echo -e " ✓ Pest testing framework"
|
|
echo -e " ✓ Laravel Pint code style"
|
|
echo -e " ✓ Queue workers & scheduler (optional profiles)"
|
|
echo ""
|
|
echo -e "${YELLOW}Common Commands:${NC}"
|
|
echo -e " docker-compose exec app php artisan <command>"
|
|
echo -e " docker-compose exec app composer <command>"
|
|
echo -e " docker-compose exec app ./vendor/bin/pest"
|
|
echo -e " docker-compose logs -f app"
|
|
echo ""
|
|
echo -e "${YELLOW}Stop containers:${NC}"
|
|
echo -e " docker-compose down"
|
|
echo ""
|