10 Commits

Author SHA1 Message Date
vbevdev a2fc1ed141 deploy dry run regulated via var 2026-07-05 02:02:59 +03:00
vbevdev 3a0e3d419c deploy backup step is now skipable 2026-07-05 01:54:23 +03:00
vbevdev 77ba40f657 fixed password trasfer on sudo backup 2026-07-04 21:00:29 +03:00
vbevdev 5f86776b83 create backup on deploy as sudo to prevent "permission denied" errors 2026-07-04 20:53:53 +03:00
vbevdev bd292c4e84 deploy dir moved from secrets to vars 2026-07-04 20:06:00 +03:00
vbevdev db7d350df5 ideas moved to repo wiki 2026-07-04 19:27:54 +03:00
vbevdev 8f860d5fe0 deleted unused action 2026-07-04 19:27:54 +03:00
vbevdev 0e278211ca deploy on gitea workflow
Reviewed-on: #3
2026-07-04 16:20:41 +00:00
vbevdev 281375a7dd Experiment/runner (#2)
Gitea Actions Demo / Explore-Gitea-Actions (push) Successful in 6s
Reviewed-on: #2
2026-07-03 21:15:23 +00:00
vbevdev ec2a17efd9 Merge pull request 'Experiment/runner' (#1) from experiment/runner into main
Gitea Actions Demo / Explore-Gitea-Actions (push) Successful in 7s
Reviewed-on: #1
2026-06-16 02:46:34 +00:00
3 changed files with 16 additions and 56 deletions
@@ -1,29 +0,0 @@
name: '🧼 Telegram message escape'
description: 'Automatically escapes dots, dashes, and exclamation marks for Telegram MarkdownV2'
inputs:
message:
description: 'The raw text string to escape'
required: true
outputs:
escaped_message:
description: 'The safely escaped string ready for Telegram'
value: ${{ steps.escape.outputs.result }}
runs:
using: 'composite'
steps:
- id: escape
shell: bash
env:
RAW_MESSAGE: ${{ inputs.message }}
run: |
MSG="$RAW_MESSAGE"
MSG="${MSG//-/\\-}"
MSG="${MSG//./\\.}"
MSG="${MSG//!/\\!}"
echo "result<<EOF" >> $GITHUB_OUTPUT
echo "$MSG" >> $GITHUB_OUTPUT
echo "EOF" >> $GITHUB_OUTPUT
-19
View File
@@ -1,19 +0,0 @@
name: Gitea Actions Demo
run-name: ${{ gitea.actor }} is testing out Gitea Actions 🚀
on: [push]
jobs:
Explore-Gitea-Actions:
runs-on: ubuntu-latest
steps:
- run: echo "🎉 The job was automatically triggered by a ${{ gitea.event_name }} event."
- run: echo "🐧 This job is now running on a ${{ runner.os }} server hosted by Gitea!"
- run: echo "🔎 The name of your branch is ${{ gitea.ref }} and your repository is ${{ gitea.repository }}."
- name: Check out repository code
uses: actions/checkout@v4
- run: echo "💡 The ${{ gitea.repository }} repository has been cloned to the runner."
- run: echo "🖥️ The workflow is now ready to test your code on the runner."
- name: List files in the repository
run: |
ls ${{ gitea.workspace }}
- run: echo "🍏 This job's status is ${{ job.status }}."
+16 -8
View File
@@ -23,11 +23,12 @@ jobs:
ssh_host: ${{ secrets.SSH_HOST }} ssh_host: ${{ secrets.SSH_HOST }}
- name: 📦 Create backup of data/ folder - name: 📦 Create backup of data/ folder
if: ${{ vars.DEPLOY_BACKUP_ENABLED == 'true' }}
env: env:
SSHPASS: ${{ secrets.SSH_PASSWORD }} SSHPASS: ${{ secrets.SSH_PASSWORD }}
SSH_USERNAME: ${{ secrets.SSH_USERNAME }} SSH_USERNAME: ${{ secrets.SSH_USERNAME }}
SSH_HOST: ${{ secrets.SSH_HOST }} SSH_HOST: ${{ secrets.SSH_HOST }}
DEPLOY_DIRECTORY: ${{ secrets.DEPLOY_DIRECTORY }} DEPLOY_DIRECTORY: ${{ vars.DEPLOY_DIRECTORY }}
REF_NAME: ${{ env.CLEAN_REF_NAME }} REF_NAME: ${{ env.CLEAN_REF_NAME }}
run: | run: |
sshpass -e ssh -p 22 "$SSH_USERNAME@$SSH_HOST" bash -s << EOT sshpass -e ssh -p 22 "$SSH_USERNAME@$SSH_HOST" bash -s << EOT
@@ -42,13 +43,13 @@ jobs:
echo "Creating backup of data/ into \${BACKUP_FILE}..." echo "Creating backup of data/ into \${BACKUP_FILE}..."
if [ -d "data" ]; then if [ -d "data" ]; then
tar -czf "\${BACKUP_FILE}" data echo "$SSHPASS" | sudo -S tar -czf "\${BACKUP_FILE}" data
echo "✅ Backup created successfully!" echo "✅ Backup created successfully!"
else else
echo "⚡️ No data/ folder, backup creation skipped." echo "⚡️ No data/ folder, backup creation skipped."
fi fi
find backups/ -type f -name "backup-*.tar.gz" -mtime +7 -delete echo "$SSHPASS" | sudo -S find backups/ -type f -name "backup-*.tar.gz" -mtime +7 -delete
EOT EOT
- name: 🏗️ Create docker-compose file - name: 🏗️ Create docker-compose file
@@ -56,7 +57,7 @@ jobs:
SSHPASS: ${{ secrets.SSH_PASSWORD }} SSHPASS: ${{ secrets.SSH_PASSWORD }}
SSH_USERNAME: ${{ secrets.SSH_USERNAME }} SSH_USERNAME: ${{ secrets.SSH_USERNAME }}
SSH_HOST: ${{ secrets.SSH_HOST }} SSH_HOST: ${{ secrets.SSH_HOST }}
DEPLOY_DIRECTORY: ${{ secrets.DEPLOY_DIRECTORY }} DEPLOY_DIRECTORY: ${{ vars.DEPLOY_DIRECTORY }}
REF_NAME: ${{ env.CLEAN_REF_NAME }} REF_NAME: ${{ env.CLEAN_REF_NAME }}
run: | run: |
sshpass -e ssh -p 22 "$SSH_USERNAME@$SSH_HOST" \ sshpass -e ssh -p 22 "$SSH_USERNAME@$SSH_HOST" \
@@ -71,7 +72,7 @@ jobs:
SSHPASS: ${{ secrets.SSH_PASSWORD }} SSHPASS: ${{ secrets.SSH_PASSWORD }}
SSH_USERNAME: ${{ secrets.SSH_USERNAME }} SSH_USERNAME: ${{ secrets.SSH_USERNAME }}
SSH_HOST: ${{ secrets.SSH_HOST }} SSH_HOST: ${{ secrets.SSH_HOST }}
DEPLOY_DIRECTORY: ${{ secrets.DEPLOY_DIRECTORY }} DEPLOY_DIRECTORY: ${{ vars.DEPLOY_DIRECTORY }}
BESZEL_AGENT_KEY: ${{ secrets.BESZEL_AGENT_KEY }} BESZEL_AGENT_KEY: ${{ secrets.BESZEL_AGENT_KEY }}
BESZEL_AGENT_TOKEN: ${{ secrets.BESZEL_AGENT_TOKEN }} BESZEL_AGENT_TOKEN: ${{ secrets.BESZEL_AGENT_TOKEN }}
BESZEL_HUB_URL: ${{ vars.BESZEL_HUB_URL }} BESZEL_HUB_URL: ${{ vars.BESZEL_HUB_URL }}
@@ -117,7 +118,9 @@ jobs:
SSHPASS: ${{ secrets.SSH_PASSWORD }} SSHPASS: ${{ secrets.SSH_PASSWORD }}
SSH_USERNAME: ${{ secrets.SSH_USERNAME }} SSH_USERNAME: ${{ secrets.SSH_USERNAME }}
SSH_HOST: ${{ secrets.SSH_HOST }} SSH_HOST: ${{ secrets.SSH_HOST }}
DEPLOY_DIRECTORY: ${{ secrets.DEPLOY_DIRECTORY }} DEPLOY_DIRECTORY: ${{ vars.DEPLOY_DIRECTORY }}
DEPLOY_LOG_FILE: /tmp/deploy-${{ env.CLEAN_REF_NAME }}.log
DRY_RUN_ENABLED: ${{ vars.DEPLOY_DRY_RUN_ENABLED }}
REF_NAME: ${{ env.CLEAN_REF_NAME }} REF_NAME: ${{ env.CLEAN_REF_NAME }}
TELEGRAM_TOKEN: ${{ secrets.TELEGRAM_DEPLOY_BOT_TOKEN }} TELEGRAM_TOKEN: ${{ secrets.TELEGRAM_DEPLOY_BOT_TOKEN }}
TELEGRAM_CHAT: ${{ secrets.TELEGRAM_DEPLOY_CHAT_ID }} TELEGRAM_CHAT: ${{ secrets.TELEGRAM_DEPLOY_CHAT_ID }}
@@ -128,7 +131,6 @@ jobs:
FAILURE_MESSAGE: |- FAILURE_MESSAGE: |-
❌ <b>Ошибка деплоя!</b> ❌ <b>Ошибка деплоя!</b>
Релиз: <code>${{ gitea.ref_name }}</code> Релиз: <code>${{ gitea.ref_name }}</code>
DEPLOY_LOG_FILE: /tmp/deploy-${{ env.CLEAN_REF_NAME }}.log
run: | run: |
sshpass -e ssh -p 22 "$SSH_USERNAME@$SSH_HOST" bash -s << EOT sshpass -e ssh -p 22 "$SSH_USERNAME@$SSH_HOST" bash -s << EOT
set -e set -e
@@ -136,8 +138,14 @@ jobs:
nohup bash -c ' nohup bash -c '
sleep 5 sleep 5
if [ "${DRY_RUN_ENABLED}" = "true" ]; then
DRY_RUN_FLAG="--dry-run"
else
DRY_RUN_FLAG=""
fi
if docker compose --dry-run -f "docker-compose-${REF_NAME}.yml" up -d --remove-orphans > ${DEPLOY_LOG_FILE} 2>&1; then if docker compose \${DRY_RUN_FLAG} -f "docker-compose-${REF_NAME}.yml" up -d --remove-orphans > ${DEPLOY_LOG_FILE} 2>&1; then
curl -s -X POST "https://api.telegram.org/bot${TELEGRAM_TOKEN}/sendMessage" \ curl -s -X POST "https://api.telegram.org/bot${TELEGRAM_TOKEN}/sendMessage" \
--proxy "${PROXY_URL}" \ --proxy "${PROXY_URL}" \
-d "chat_id=${TELEGRAM_CHAT}" \ -d "chat_id=${TELEGRAM_CHAT}" \