Compare commits
52 Commits
main
..
ee413eda26
| Author | SHA1 | Date | |
|---|---|---|---|
| ee413eda26 | |||
| 1aa8bae409 | |||
| 158277f0ff | |||
| 730077376a | |||
| da67941519 | |||
| 264225bb8b | |||
| cebc67e9a4 | |||
| 6bb16b3b1f | |||
| 327f4368c6 | |||
| b5ebd32a0d | |||
| b840b6bbbc | |||
| 9c0cff6a1b | |||
| 7088ab43ad | |||
| c8fc8776fd | |||
| feaf427969 | |||
| 8700d316fa | |||
| fdcd3eac2e | |||
| df4d6e064e | |||
| 557194a01f | |||
| 8b7568c61b | |||
| 18687a2f01 | |||
| 7115cd5d36 | |||
| 52cd7840ef | |||
| 6db07787fa | |||
| 23846918e6 | |||
| af20fc9662 | |||
| 8f48806208 | |||
| 15cafea367 | |||
| 0dd86c53dd | |||
| 457bf8e586 | |||
| 890136634a | |||
| c159c0177f | |||
| d0a4990780 | |||
| 98efc877af | |||
| 95ac23906d | |||
| 29d66974cb | |||
| 10d7773a13 | |||
| 3f9db6cdc1 | |||
| ca2df02029 | |||
| 6d859cf79e | |||
| fbae09ebe1 | |||
| f331f754e1 | |||
| b9a1d5bf7d | |||
| 03e987e73f | |||
| 2a47f28465 | |||
| 6f55ebb99c | |||
| 2bdfa27624 | |||
| ccdac3847f | |||
| 0b1260614e | |||
| 40b621448c | |||
| 9572e20a2c | |||
| 74b8769195 |
@@ -0,0 +1,29 @@
|
|||||||
|
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
|
||||||
@@ -0,0 +1,19 @@
|
|||||||
|
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 }}."
|
||||||
@@ -23,12 +23,11 @@ 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: ${{ vars.DEPLOY_DIRECTORY }}
|
DEPLOY_DIRECTORY: ${{ secrets.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
|
||||||
@@ -43,13 +42,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
|
||||||
echo "$SSHPASS" | sudo -S tar -czf "\${BACKUP_FILE}" data
|
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
|
||||||
|
|
||||||
echo "$SSHPASS" | sudo -S find backups/ -type f -name "backup-*.tar.gz" -mtime +7 -delete
|
find backups/ -type f -name "backup-*.tar.gz" -mtime +7 -delete
|
||||||
EOT
|
EOT
|
||||||
|
|
||||||
- name: 🏗️ Create docker-compose file
|
- name: 🏗️ Create docker-compose file
|
||||||
@@ -57,7 +56,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: ${{ vars.DEPLOY_DIRECTORY }}
|
DEPLOY_DIRECTORY: ${{ secrets.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" \
|
||||||
@@ -72,7 +71,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: ${{ vars.DEPLOY_DIRECTORY }}
|
DEPLOY_DIRECTORY: ${{ secrets.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 }}
|
||||||
@@ -118,9 +117,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: ${{ vars.DEPLOY_DIRECTORY }}
|
DEPLOY_DIRECTORY: ${{ secrets.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 }}
|
||||||
@@ -131,6 +128,7 @@ 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
|
||||||
@@ -138,14 +136,8 @@ 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_FLAG} -f "docker-compose-${REF_NAME}.yml" up -d --remove-orphans > ${DEPLOY_LOG_FILE} 2>&1; then
|
if docker compose --dry-run -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}" \
|
||||||
|
|||||||
Reference in New Issue
Block a user