-
Notifications
You must be signed in to change notification settings - Fork 0
154 lines (131 loc) · 4.66 KB
/
ci.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
name: Twitch Bot CI/CD Pipeline
on:
push:
branches:
- main
pull_request:
branches:
- main
workflow_dispatch:
jobs:
build:
runs-on: self-hosted # Runs directly on your Raspberry Pi
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
if [ ! -f "venv/.requirements_installed" ] || ! cmp -s requirements.txt venv/.requirements_installed; then
python -m pip install --upgrade pip
pip install -r requirements.txt
cp requirements.txt venv/.requirements_installed
fi
deploy:
runs-on: self-hosted
needs: build
if: github.ref == 'refs/heads/main' && github.event_name == 'push'
steps:
- name: Deploy to Raspberry Pi
env:
GOOGLE_CREDENTIALS_JSON: ${{ secrets.GOOGLE_CREDENTIALS_JSON }}
run: |
set -e
REVUBOT_DIR=~/revbot
REPO_URL=https://github.com/Revulate/revbot.git
BACKUP_DIR=~/revbot_backup_$(date +%Y%m%d_%H%M%S)
# Backup current version
if [ -d "$REVUBOT_DIR" ]; then
cp -r $REVUBOT_DIR $BACKUP_DIR
fi
mkdir -p $REVUBOT_DIR
cd $REVUBOT_DIR
if [ -d ".git" ]; then
git fetch origin
git checkout main
git reset --hard origin/main
else
git clone --branch main $REPO_URL .
fi
if [ ! -d "venv" ]; then
python3.11 -m venv venv
fi
source venv/bin/activate
if [ ! -f "venv/.requirements_installed" ] || ! cmp -s requirements.txt venv/.requirements_installed; then
pip install -r requirements.txt
cp requirements.txt venv/.requirements_installed
fi
# Ensure correct file permissions for credentials.json
echo "$GOOGLE_CREDENTIALS_JSON" > credentials.json
chmod 600 credentials.json
# Install Node.js and PM2 if not present
if ! command -v node &> /dev/null; then
curl -fsSL https://deb.nodesource.com/setup_20.x | sudo -E bash -
sudo apt-get install -y nodejs
fi
if ! command -v pm2 &> /dev/null; then
sudo npm install -g pm2
fi
# Create or update PM2 ecosystem config
cat <<EOF > ecosystem.config.js
module.exports = {
apps: [{
name: "twitch-bot",
script: "bot.py",
interpreter: "$(which python)",
watch: true,
ignore_watch: ["node_modules", "logs"],
max_memory_restart: "1G",
env: {
NODE_ENV: "development",
PYTHONUNBUFFERED: "1"
},
env_production: {
NODE_ENV: "production",
PYTHONUNBUFFERED: "1"
}
}]
}
EOF
# Set up the database to ensure all tables exist
python -c 'from utils import setup_database; setup_database()'
# Run database migrations if any
if [ -f "migrate.py" ]; then
python migrate.py
fi
# Start or restart the bot using PM2
pm2 start ecosystem.config.js --update-env || pm2 delete twitch-bot && pm2 start ecosystem.config.js --update-env
pm2 save
sudo pm2 startup systemd -u $USER --hp $HOME
# Health check
sleep 10
if ! pm2 list | grep -q "online"; then
echo "Error: twitch-bot is not running after restart"
# Rollback
echo "Rolling back to previous version..."
rm -rf $REVUBOT_DIR
mv $BACKUP_DIR $REVUBOT_DIR
cd $REVUBOT_DIR
pm2 start ecosystem.config.js --update-env
exit 1
fi
echo "Deployment completed successfully"
- name: Cleanup old backups
run: |
find ~/revbot_backup_* -maxdepth 0 -type d -mtime +7 -exec rm -rf {} +
- name: Notify on success
if: success()
run: echo "Deployment successful" # Replace with your notification method
- name: Notify on failure
if: failure()
run: echo "Deployment failed" # Replace with your notification method