Update .gitea/workflows/main.yml

This commit is contained in:
2026-03-24 00:59:01 +00:00
parent 1d873d7c22
commit 7c25ab7120

View File

@@ -4,11 +4,9 @@ on:
workflow_call: workflow_call:
inputs: inputs:
build-run-id: build-run-id:
description: 'ID da execução que gerou o artefato'
required: true required: true
type: string type: string
artifact-name: artifact-name:
description: 'Nome do artefato'
required: true required: true
type: string type: string
secrets: secrets:
@@ -38,32 +36,30 @@ jobs:
password: ${{ secrets.NODE3_PASSWORD }} password: ${{ secrets.NODE3_PASSWORD }}
steps: steps:
- name: 🔍 Verificar Sanidade
run: |
echo "SHA do commit: ${{ github.sha }}"
if [ -z "${{ matrix.password }}" ]; then
echo "❌ ERRO: A secret para ${{ matrix.node_name }} chegou VAZIA!"
exit 1
fi
- name: 📥 Baixar artefatos - name: 📥 Baixar artefatos
uses: actions/download-artifact@v3 uses: actions/download-artifact@v3
with: with:
name: ${{ inputs.artifact-name }} name: ${{ inputs.artifact-name }}
path: ./builds path: ./builds
- name: 🚀 Deploy para ${{ matrix.node_name }} (${{ matrix.host }}) - name: 🚀 Deploy para ${{ matrix.node_name }}
shell: bash shell: bash
run: | run: |
set -x set -e
shopt -s globstar shopt -s globstar
# Tenta instalar sshpass (se não for root, vai falhar, mas seu runner parece ser root) # Verificação silenciosa de senha
if ! command -v sshpass &> /dev/null; then if [ -z "${{ matrix.password }}" ]; then
apt-get update && apt-get install -y sshpass || apt install -y sshpass echo "❌ ERRO: Password para ${{ matrix.node_name }} não configurada."
exit 1
fi fi
echo "🔧 Criando diretório temporário remoto..." # Instalação silenciosa do sshpass
if ! command -v sshpass &> /dev/null; then
apt-get update -qq && apt-get install -y -qq sshpass &> /dev/null
fi
echo "🔧 [${{ matrix.node_name }}] Preparando ambiente..."
sshpass -p "${{ matrix.password }}" \ sshpass -p "${{ matrix.password }}" \
ssh -o StrictHostKeyChecking=no -p ${{ matrix.port }} \ ssh -o StrictHostKeyChecking=no -p ${{ matrix.port }} \
root@${{ matrix.host }} "mkdir -p ${{ env.REMOTE_TMP_DIR }}" root@${{ matrix.host }} "mkdir -p ${{ env.REMOTE_TMP_DIR }}"
@@ -73,28 +69,26 @@ jobs:
PLUGIN_NAME=$(basename "$jar_file") PLUGIN_NAME=$(basename "$jar_file")
REMOTE_JAR_PATH="${{ env.REMOTE_TMP_DIR }}/${PLUGIN_NAME}" REMOTE_JAR_PATH="${{ env.REMOTE_TMP_DIR }}/${PLUGIN_NAME}"
echo "📤 Enviando ${PLUGIN_NAME}..." echo "📤 [${{ matrix.node_name }}] Enviando: ${PLUGIN_NAME}"
sshpass -p "${{ matrix.password }}" \ sshpass -p "${{ matrix.password }}" \
sftp -o StrictHostKeyChecking=no -P ${{ matrix.port }} \ sftp -o StrictHostKeyChecking=no -P ${{ matrix.port }} \
root@${{ matrix.host }} <<EOF root@${{ matrix.host }} <<EOF &> /dev/null
put "${jar_file}" "${REMOTE_JAR_PATH}" put "${jar_file}" "${REMOTE_JAR_PATH}"
bye bye
EOF EOF
echo "🔐 Atualizando containers e reiniciando..." echo "🔐 [${{ matrix.node_name }}] Atualizando containers..."
sshpass -p "${{ matrix.password }}" \ sshpass -p "${{ matrix.password }}" \
ssh -o StrictHostKeyChecking=no -p ${{ matrix.port }} \ ssh -o StrictHostKeyChecking=no -p ${{ matrix.port }} \
root@${{ matrix.host }} " root@${{ matrix.host }} "
set -ex
find '${{ env.PTERO_VOLUME_PATH }}' -type f -path '*/plugins/${PLUGIN_NAME}' | while read -r plugin_path; do find '${{ env.PTERO_VOLUME_PATH }}' -type f -path '*/plugins/${PLUGIN_NAME}' | while read -r plugin_path; do
echo \"-> Atualizando em: \${plugin_path}\" echo \" -> Atualizando: \${plugin_path}\"
cp '${REMOTE_JAR_PATH}' \"\${plugin_path}\" cp '${REMOTE_JAR_PATH}' \"\${plugin_path}\"
server_id=\$(echo \"\${plugin_path}\" | cut -d'/' -f6) server_id=\$(echo \"\${plugin_path}\" | cut -d'/' -f6)
echo \"-> Reiniciando container: \${server_id}\" docker container restart \"\${server_id}\" &> /dev/null || true
docker container restart \"\${server_id}\" || true
done done
rm -f '${REMOTE_JAR_PATH}' rm -f '${REMOTE_JAR_PATH}'
" "
fi fi
done done
echo "🌟 Node ${{ matrix.host }} finalizado!" echo "✅ [${{ matrix.node_name }}] Concluído!"