mirror of
https://github.com/BreizhHardware/ntfy_alerts.git
synced 2026-03-18 21:40:38 +01:00
138 lines
3.9 KiB
YAML
138 lines
3.9 KiB
YAML
name: Build et Push Docker Dev Image
|
|
|
|
on:
|
|
push:
|
|
branches:
|
|
- dev
|
|
|
|
jobs:
|
|
build-binary:
|
|
if: ${{ github.actor != 'dependabot[bot]' && !startsWith(github.ref, 'refs/heads/dependabot/') }}
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- name: Checkout code
|
|
uses: actions/checkout@v4
|
|
|
|
- name: Installer Rust
|
|
uses: actions-rs/toolchain@v1
|
|
with:
|
|
toolchain: stable
|
|
target: x86_64-unknown-linux-musl
|
|
override: true
|
|
|
|
- name: Installer cross
|
|
run: cargo install cross
|
|
|
|
- name: Créer Cross.toml pour spécifier OpenSSL vendored
|
|
run: |
|
|
cat > Cross.toml << 'EOF'
|
|
[build.env]
|
|
passthrough = [
|
|
"RUSTFLAGS",
|
|
"OPENSSL_STATIC",
|
|
"OPENSSL_NO_VENDOR"
|
|
]
|
|
EOF
|
|
|
|
- name: Construire avec cross et OpenSSL vendored
|
|
env:
|
|
OPENSSL_STATIC: 1
|
|
RUSTFLAGS: "-C target-feature=+crt-static"
|
|
OPENSSL_NO_VENDOR: 0
|
|
run: |
|
|
cross build --release --target x86_64-unknown-linux-musl --features vendored-openssl
|
|
|
|
- name: Préparer le binaire
|
|
run: |
|
|
mkdir -p release
|
|
cp target/x86_64-unknown-linux-musl/release/github-ntfy release/github-ntfy
|
|
|
|
- name: Upload binaire comme artifact
|
|
uses: actions/upload-artifact@v4
|
|
with:
|
|
name: github-ntfy
|
|
path: release/github-ntfy
|
|
|
|
build-frontend:
|
|
if: ${{ github.actor != 'dependabot[bot]' && !startsWith(github.ref, 'refs/heads/dependabot/') }}
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- name: Checkout code
|
|
uses: actions/checkout@v4
|
|
|
|
- name: Setup Node.js
|
|
uses: actions/setup-node@v4
|
|
with:
|
|
node-version: '20'
|
|
|
|
- name: Setup PNPM
|
|
uses: pnpm/action-setup@v2
|
|
with:
|
|
version: '10.x'
|
|
run_install: false
|
|
|
|
- name: Build Frontend (Nuxt)
|
|
run: |
|
|
cd web
|
|
pnpm install
|
|
pnpm generate
|
|
|
|
- name: Vérifier le contenu du répertoire output/public
|
|
run: |
|
|
ls -la web/.output/public || echo "Le répertoire .output/public n'existe pas!"
|
|
|
|
- name: Upload frontend comme artifact
|
|
uses: actions/upload-artifact@v4
|
|
with:
|
|
name: nuxt-frontend
|
|
path: web/.output/public # Cibler spécifiquement le répertoire public
|
|
|
|
docker-build-push:
|
|
if: ${{ github.actor != 'dependabot[bot]' && !startsWith(github.ref, 'refs/heads/dependabot/') }}
|
|
needs: [build-binary, build-frontend]
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- name: Checkout code
|
|
uses: actions/checkout@v4
|
|
|
|
- name: Configurer Docker Buildx
|
|
uses: docker/setup-buildx-action@v3
|
|
|
|
- name: Login Docker Hub
|
|
uses: docker/login-action@v3
|
|
with:
|
|
username: ${{ secrets.DOCKER_USERNAME }}
|
|
password: ${{ secrets.DOCKER_PASSWORD }}
|
|
|
|
- name: Télécharger le binaire
|
|
uses: actions/download-artifact@v4
|
|
with:
|
|
name: github-ntfy
|
|
path: binaries
|
|
|
|
- name: Télécharger le frontend
|
|
uses: actions/download-artifact@v4
|
|
with:
|
|
name: nuxt-frontend
|
|
path: web/.output/public
|
|
|
|
- name: Préparer les fichiers pour Docker
|
|
run: |
|
|
chmod +x binaries/github-ntfy
|
|
mkdir -p docker-build
|
|
cp binaries/github-ntfy docker-build/
|
|
mkdir -p docker-build/web-output/public
|
|
cp -r web/.output/public/* docker-build/web-output/public/
|
|
cp nginx.conf docker-build/
|
|
cp entrypoint.sh docker-build/
|
|
cp Dockerfile docker-build/
|
|
chmod +x docker-build/entrypoint.sh
|
|
|
|
- name: Construire et pousser l'image Docker
|
|
uses: docker/build-push-action@v6
|
|
with:
|
|
context: docker-build
|
|
push: true
|
|
tags: ${{ secrets.DOCKER_USERNAME }}/github-ntfy:dev
|
|
file: docker-build/Dockerfile
|