web2print-service/.forgejo/workflows/deploy.yml

78 lines
2.3 KiB
YAML
Raw Normal View History

name: Deploy
on:
push:
branches:
- main
env:
DEPLOY_PATH: /var/www/web2print
jobs:
deploy:
2026-03-05 07:03:01 +01:00
runs-on: docker
steps:
- name: Checkout
run: |
git clone --depth 1 --branch main https://forge.studio-variable.com/${{ github.repository }}.git .
- name: Setup SSH
run: |
apt-get update -qq && apt-get install -y -qq rsync openssh-client
mkdir -p ~/.ssh
echo "${{ secrets.SSH_PRIVATE_KEY }}" > ~/.ssh/id_ed25519
chmod 600 ~/.ssh/id_ed25519
cat > ~/.ssh/config <<EOF
Host *
StrictHostKeyChecking no
UserKnownHostsFile /dev/null
BatchMode yes
IdentitiesOnly yes
EOF
chmod 600 ~/.ssh/config
- name: Deploy files
run: |
ssh -i ~/.ssh/id_ed25519 ${{ vars.USERNAME }}@${{ vars.HOST }} "mkdir -p /tmp/web2print-deploy"
rsync_deploy() {
src="$1"
dst="$2"
shift 2
cmd="rsync -az --delete --no-perms --no-owner --no-group"
for excl in "$@"; do
cmd="$cmd --exclude=$excl"
done
cmd="$cmd -e 'ssh -i ~/.ssh/id_ed25519' $src ${{ vars.USERNAME }}@${{ vars.HOST }}:/tmp/web2print-deploy/$dst"
echo "$cmd"
eval $cmd
}
rsync_deploy config/ "config/"
rsync_deploy src/ "src/"
rsync_deploy public/ "public/"
- name: Apply on server
run: |
ssh -i ~/.ssh/id_ed25519 ${{ vars.USERNAME }}@${{ vars.HOST }} "
set -e
DEPLOY_PATH=/var/www/web2print
echo 'Copie des fichiers...'
sudo cp -r /tmp/web2print-deploy/config/. \$DEPLOY_PATH/config/
sudo cp -r /tmp/web2print-deploy/src/. \$DEPLOY_PATH/src/
sudo cp -r /tmp/web2print-deploy/public/. \$DEPLOY_PATH/public/
echo 'Configuration des permissions...'
sudo chown -R www-data:www-data \$DEPLOY_PATH
sudo chmod -R 755 \$DEPLOY_PATH
sudo chmod -R 775 \$DEPLOY_PATH/logs
sudo chmod -R 775 \$DEPLOY_PATH/tmp
sudo chmod 640 \$DEPLOY_PATH/config/config.php
echo 'Nettoyage...'
rm -rf /tmp/web2print-deploy
echo 'Deploiement termine avec succes!'
"