FTP
Pour publier sur un simple serveur FTP, il faut utiliser une action GitHub, c’est à dire une tâche qui va s’exécuter à chaque modification du site.
Assurez-vous d’avoir toutes l’informations nécessaires :
FTP_HOSTNAME
:[serveur hôte ci-dessus]
FTP_USERNAME
:[nom de l'utilisateur ci-dessus]
FTP_PASSWORD
:[mot de passe ci-dessus]
FTP_PORT
:21
FTP_LOCAL_DIR
:./public/
FTP_SERVER_DIR
:[dossier vers le site]/
NOTE : Ne pas oublier le /
à la fin du FTP_SERVER_DIR
. Exemple : /var/www/
Configuration du déploiement
Aller sur GitHub, dans “Settings”, “Secrets and variables”, “Actions”, puis dans l’onglet “Secrets”, définissez les repository secrets ci-dessus.
Créer l’action automatisée dans le fichier .github/workflows/deploy.yml
name: FTP deployment
on:
push:
branches:
- main
jobs:
deploy:
runs-on: ubuntu-20.04
concurrency:
group: ${{ github.workflow }}
cancel-in-progress: true
steps:
- uses: actions/checkout@v3
with:
submodules: true
fetch-depth: 1
- name: Setup Hugo
uses: peaceiris/actions-hugo@v2
with:
hugo-version: 'latest'
extended: true
- name: Setup Node
uses: actions/setup-node@v3
with:
node-version: '16'
cache: 'yarn'
- name: Install JS dependencies
run: yarn install --frozen-lockfile
- name: Build
run: hugo -e production --minify
- name: SFTP Deploy
uses: SamKirkland/FTP-Deploy-Action@v4.3.4
with:
server: ${{ secrets.FTP_HOSTNAME }}
username: ${{ secrets.FTP_USERNAME }}
password: ${{ secrets.FTP_PASSWORD }}
local-dir: ${{ secrets.FTP_LOCAL_DIR }}
server-dir: ${{ secrets.FTP_SERVER_DIR }}
- name: Notification Slack en cas d'échec
uses: ravsamhq/notify-slack-action@2.3.0
if: always()
with:
status: ${{ job.status }}
notify_when: "failure"
notification_title: ""
env:
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }}