Update ecosystem.config.js #81
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Twitch Bot CI/CD Pipeline | |
on: | |
push: | |
branches: | |
- main | |
pull_request: | |
branches: | |
- main | |
workflow_dispatch: | |
jobs: | |
build: | |
runs-on: self-hosted | |
steps: | |
- name: Checkout Repository | |
uses: actions/checkout@v3 | |
- name: Cache pip packages | |
uses: actions/cache@v3 | |
with: | |
path: ~/.cache/pip | |
key: ${{ runner.os }}-pip-${{ hashFiles('**/requirements.txt') }} | |
restore-keys: | | |
${{ runner.os }}-pip- | |
- name: Set up Python Virtual Environment and Install Dependencies | |
run: | | |
if [ ! -d "venv" ]; then | |
python3.11 -m venv venv | |
fi | |
source venv/bin/activate | |
pip install --upgrade pip | |
pip install -r requirements.txt | |
deploy: | |
runs-on: self-hosted | |
needs: build | |
if: github.ref == 'refs/heads/main' && github.event_name == 'push' | |
steps: | |
- name: Check current user and environment | |
run: | | |
echo "Current user: $(whoami)" | |
echo "User ID: $(id -u)" | |
echo "Groups: $(groups)" | |
echo "Home directory: $HOME" | |
echo "Current directory: $(pwd)" | |
echo "PATH: $PATH" | |
- name: Check system dependencies | |
run: | | |
python3.11 --version | |
pip --version | |
node --version || echo "Node.js not found" | |
npm --version || echo "npm not found" | |
pm2 --version || echo "PM2 not found" | |
- name: Deploy to Raspberry Pi | |
env: | |
GOOGLE_CREDENTIALS_JSON: ${{ secrets.GOOGLE_CREDENTIALS_JSON }} | |
TWITCH_CLIENT_ID: ${{ secrets.TWITCH_CLIENT_ID }} | |
TWITCH_CLIENT_SECRET: ${{ secrets.TWITCH_CLIENT_SECRET }} | |
BOT_NICK: ${{ secrets.BOT_NICK }} | |
ACCESS_TOKEN: ${{ secrets.ACCESS_TOKEN }} | |
REFRESH_TOKEN: ${{ secrets.REFRESH_TOKEN }} | |
TWITCH_CHANNELS: ${{ secrets.TWITCH_CHANNELS }} | |
COMMAND_PREFIX: ${{ secrets.COMMAND_PREFIX }} | |
ADMIN_USERS: ${{ secrets.ADMIN_USERS }} | |
BOT_USER_ID: ${{ secrets.BOT_USER_ID }} | |
BROADCASTER_USER_ID: ${{ secrets.BROADCASTER_USER_ID }} | |
run: | | |
set -e | |
echo "Starting deployment process..." | |
REVUBOT_DIR=$HOME/revbot | |
REPO_URL=https://github.com/Revulate/revbot.git | |
BACKUP_DIR=$HOME/revbot_backup_$(date +%Y%m%d_%H%M%S) | |
# Debug: Print environment variables (be careful not to expose sensitive information) | |
echo "TWITCH_CLIENT_ID is set: $([[ -n $TWITCH_CLIENT_ID ]] && echo 'Yes' || echo 'No')" | |
echo "TWITCH_CLIENT_SECRET is set: $([[ -n $TWITCH_CLIENT_SECRET ]] && echo 'Yes' || echo 'No')" | |
echo "BOT_NICK is set: $([[ -n $BOT_NICK ]] && echo 'Yes' || echo 'No')" | |
echo "ACCESS_TOKEN is set: $([[ -n $ACCESS_TOKEN ]] && echo 'Yes' || echo 'No')" | |
echo "REFRESH_TOKEN is set: $([[ -n $REFRESH_TOKEN ]] && echo 'Yes' || echo 'No')" | |
echo "TWITCH_CHANNELS is set: $([[ -n $TWITCH_CHANNELS ]] && echo 'Yes' || echo 'No')" | |
echo "COMMAND_PREFIX is set: $([[ -n $COMMAND_PREFIX ]] && echo 'Yes' || echo 'No')" | |
echo "ADMIN_USERS is set: $([[ -n $ADMIN_USERS ]] && echo 'Yes' || echo 'No')" | |
echo "BOT_USER_ID is set: $([[ -n $BOT_USER_ID ]] && echo 'Yes' || echo 'No')" | |
echo "BROADCASTER_USER_ID is set: $([[ -n $BROADCASTER_USER_ID ]] && echo 'Yes' || echo 'No')" | |
# Backup current version | |
if [ -d "$REVUBOT_DIR" ]; then | |
echo "Backing up current version..." | |
cp -r $REVUBOT_DIR $BACKUP_DIR | |
else | |
echo "No existing directory to backup." | |
fi | |
echo "Creating/updating $REVUBOT_DIR..." | |
mkdir -p $REVUBOT_DIR | |
cd $REVUBOT_DIR | |
if [ -d ".git" ]; then | |
echo "Updating existing repository..." | |
git fetch origin | |
git checkout main | |
git reset --hard origin/main | |
else | |
echo "Initializing repository..." | |
git init | |
git remote add origin $REPO_URL | |
git fetch origin | |
git checkout -b main origin/main | |
fi | |
echo "Setting up Python environment..." | |
if [ ! -d "venv" ]; then | |
python3.11 -m venv venv | |
fi | |
source venv/bin/activate | |
pip install -r requirements.txt | |
echo "Setting up credentials..." | |
echo "$GOOGLE_CREDENTIALS_JSON" > credentials.json | |
chmod 600 credentials.json | |
echo "Creating .env file..." | |
cat << EOF > .env | |
TWITCH_CLIENT_ID=$TWITCH_CLIENT_ID | |
TWITCH_CLIENT_SECRET=$TWITCH_CLIENT_SECRET | |
BOT_NICK=$BOT_NICK | |
ACCESS_TOKEN=$ACCESS_TOKEN | |
REFRESH_TOKEN=$REFRESH_TOKEN | |
TWITCH_CHANNELS=$TWITCH_CHANNELS | |
COMMAND_PREFIX=$COMMAND_PREFIX | |
ADMIN_USERS=$ADMIN_USERS | |
BOT_USER_ID=$BOT_USER_ID | |
BROADCASTER_USER_ID=$BROADCASTER_USER_ID | |
EOF | |
echo "Checking Node.js and PM2..." | |
node -v || echo "Node.js not found. Please install it manually." | |
npm install pm2 | |
export PATH="$PATH:$HOME/revbot/node_modules/.bin" | |
echo "Creating PM2 ecosystem config..." | |
cat <<EOF > ecosystem.config.js | |
module.exports = { | |
apps: [{ | |
name: "twitch-bot", | |
script: "bot.py", | |
interpreter: "$(which python)", | |
watch: false, | |
ignore_watch: ["node_modules", "logs"], | |
max_memory_restart: "1G", | |
env: { | |
NODE_ENV: "production", | |
PYTHONUNBUFFERED: "1" | |
} | |
}] | |
} | |
EOF | |
echo "Setting up database..." | |
python -c 'from utils import setup_database; setup_database()' | |
if [ -f "migrate.py" ]; then | |
echo "Running database migrations..." | |
python migrate.py | |
fi | |
echo "Starting/restarting bot with PM2..." | |
pm2 describe twitch-bot > /dev/null | |
if [ $? -eq 0 ]; then | |
pm2 restart twitch-bot | |
else | |
pm2 start ecosystem.config.js | |
fi | |
echo "Saving PM2 process list..." | |
pm2 save | |
echo "Performing health check..." | |
sleep 10 | |
if ! pm2 list | grep -q "online"; then | |
echo "Error: twitch-bot is not running after restart" | |
echo "PM2 status:" | |
pm2 list | |
echo "PM2 logs:" | |
pm2 logs --lines 50 | |
echo "Rolling back to previous version..." | |
if [ -d "$BACKUP_DIR" ]; then | |
rm -rf $REVUBOT_DIR | |
mv $BACKUP_DIR $REVUBOT_DIR | |
cd $REVUBOT_DIR | |
pm2 start ecosystem.config.js | |
echo "Rollback completed." | |
else | |
echo "No backup directory found. Cannot rollback." | |
fi | |
exit 1 | |
fi | |
echo "Deployment completed successfully" | |
- name: Cleanup old backups | |
run: | | |
find $HOME/revbot_backup_* -maxdepth 0 -type d -mtime +7 -exec rm -rf {} + | |
- name: Notify on success | |
if: success() | |
run: echo "Deployment successful" | |
- name: Notify on failure | |
if: failure() | |
run: echo "Deployment failed" |