Add vibe-kanban

This commit is contained in:
2025-12-31 01:31:54 +07:00
parent 488d7c2a76
commit a37b59f29a
41 changed files with 2004 additions and 0 deletions

82
scripts/create-task-compose.sh Executable file
View File

@@ -0,0 +1,82 @@
#!/bin/bash
# scripts/create-task-compose.sh
# Creates a task-specific Docker Compose file with all required environment variables
TASK_ID=$1
PORT_OFFSET=${2:-0}
POSTGRES_PORT=$((5432 + PORT_OFFSET))
API_PORT=$((5000 + PORT_OFFSET))
WORKER_PORT=$((5001 + PORT_OFFSET))
REDIS_PORT=$((6379 + PORT_OFFSET))
ORLEANS_SILO_PORT=$((11111 + PORT_OFFSET))
ORLEANS_GATEWAY_PORT=$((30000 + PORT_OFFSET))
# Convert to lowercase (compatible with bash 3.2+)
DB_NAME="managing_$(echo "$TASK_ID" | tr '[:upper:]' '[:lower:]')"
ORLEANS_DB_NAME="orleans_$(echo "$TASK_ID" | tr '[:upper:]' '[:lower:]')"
TASK_ID_LOWER="$(echo "$TASK_ID" | tr '[:upper:]' '[:lower:]')"
# Calculate unique task slot based on port offset (for Orleans clustering)
TASK_SLOT=$((PORT_OFFSET / 10 + 1))
SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )"
PROJECT_ROOT="$(dirname "$SCRIPT_DIR")"
COMPOSE_DIR="$PROJECT_ROOT/src/Managing.Docker"
COMPOSE_FILE="$COMPOSE_DIR/docker-compose.task-${TASK_ID}.yml"
# Escape function for Docker Compose environment variables
escape_env() {
echo "$1" | sed 's/\\/\\\\/g' | sed 's/\$/\\$/g' | sed 's/"/\\"/g'
}
cat > "$COMPOSE_FILE" << EOF
name: task-${TASK_ID_LOWER}
services:
postgres-${TASK_ID}:
image: postgres:17.5
container_name: postgres-${TASK_ID}
volumes:
- postgresdata_${TASK_ID}:/var/lib/postgresql/data
ports:
- "${POSTGRES_PORT}:5432"
restart: unless-stopped
networks:
- task-${TASK_ID}-network
environment:
- POSTGRES_USER=postgres
- POSTGRES_PASSWORD=postgres
- POSTGRES_DB=postgres
redis-${TASK_ID}:
image: redis:8.0.3
container_name: redis-${TASK_ID}
ports:
- "${REDIS_PORT}:6379"
volumes:
- redis_data_${TASK_ID}:/data
networks:
- task-${TASK_ID}-network
restart: unless-stopped
environment:
- REDIS_PASSWORD=
volumes:
postgresdata_${TASK_ID}:
redis_data_${TASK_ID}:
networks:
task-${TASK_ID}-network:
driver: bridge
EOF
echo "✅ Created $COMPOSE_FILE"
echo " PostgreSQL: localhost:$POSTGRES_PORT"
echo " Redis: localhost:$REDIS_PORT"
echo " API will run via dotnet run on port: $API_PORT"
echo " Orleans Silo: localhost:$ORLEANS_SILO_PORT"
echo " Orleans Gateway: localhost:$ORLEANS_GATEWAY_PORT"
echo " InfluxDB: Using main instance at localhost:8086"
echo " Task Slot: $TASK_SLOT"