memory/dev.sh
2025-06-03 18:48:45 +02:00

95 lines
2.7 KiB
Bash
Executable File

#!/usr/bin/env bash
set -eo pipefail
# Colors for output
GREEN='\033[0;32m'
YELLOW='\033[1;33m'
RED='\033[0;31m'
NC='\033[0m' # No Color
echo -e "${GREEN}Starting development environment for Memory Knowledge Base...${NC}"
# Get the directory of the script
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
cd "$SCRIPT_DIR"
docker volume create memory_file_storage
docker run --rm -v memory_file_storage:/data busybox chown -R 1000:1000 /data
POSTGRES_PASSWORD=543218ZrHw8Pxbs3YXzaVHq8YKVHwCj6Pz8RQkl8
echo $POSTGRES_PASSWORD > secrets/postgres_password.txt
# Create a temporary docker-compose override file to expose PostgreSQL
echo -e "${YELLOW}Creating docker-compose override to expose PostgreSQL...${NC}"
if [ ! -f docker-compose.override.yml ]; then
cat > docker-compose.override.yml << EOL
version: "3.9"
services:
qdrant:
ports:
- "6333:6333"
postgres:
ports:
# PostgreSQL port for local Celery result backend
- "15432:5432"
rabbitmq:
ports:
# UI only on localhost
- "15672:15672"
# AMQP port for local Celery clients (for local workers)
- "15673:5672"
EOL
fi
if [ ! -f .env ]; then
echo $POSTGRES_PASSWORD > .env
cat >> .env << EOL
CELERY_BROKER_PASSWORD=543218ZrHw8Pxbs3YXzaVHq8YKVHwCj6Pz8RQkl8
RABBITMQ_HOST=localhost
QDRANT_HOST=localhost
DB_HOST=localhost
VOYAGE_API_KEY=
ANTHROPIC_API_KEY=
OPENAI_API_KEY=
DB_PORT=15432
RABBITMQ_PORT=15673
EOL
fi
# Start the containers
echo -e "${GREEN}Starting docker containers...${NC}"
docker-compose up -d postgres rabbitmq qdrant
# Wait for PostgreSQL to be ready
echo -e "${YELLOW}Waiting for PostgreSQL to be ready...${NC}"
for i in {1..30}; do
if docker-compose exec postgres pg_isready -U kb > /dev/null 2>&1; then
echo -e "${GREEN}PostgreSQL is ready!${NC}"
break
fi
echo -n "."
sleep 1
done
# Initialize the database if needed
echo -e "${YELLOW}Checking if database needs initialization...${NC}"
if ! docker-compose exec postgres psql -U kb -d kb -c "SELECT 1 FROM information_schema.tables WHERE table_name = 'source_item'" | grep -q 1; then
echo -e "${GREEN}Initializing database from schema.sql...${NC}"
docker-compose exec postgres psql -U kb -d kb -f /docker-entrypoint-initdb.d/schema.sql
else
echo -e "${GREEN}Database already initialized.${NC}"
fi
echo -e "${GREEN}Development environment is ready!${NC}"
echo -e "${YELLOW}PostgreSQL is available at localhost:5432${NC}"
echo -e "${YELLOW}Username: kb${NC}"
echo -e "${YELLOW}Password: (check secrets/postgres_password.txt)${NC}"
echo -e "${YELLOW}Database: kb${NC}"
echo ""
echo -e "${GREEN}To stop the environment, run:${NC}"
echo -e "${YELLOW}docker-compose down${NC}"