Skip to content

Merge pull request #95 from Mickhat/oli-heeeckers-new-system #96

Merge pull request #95 from Mickhat/oli-heeeckers-new-system

Merge pull request #95 from Mickhat/oli-heeeckers-new-system #96

name: continuous-deploy
on:
push:
branches:
- 'master'
env:
REGISTRY: ghcr.io
IMAGE_NAME: ${{ github.repository }}
BRANCH_NAME: ${{ github.ref_name }}
COMMIT_SHA: ${{ github.sha }}
jobs:
build-and-push-image:
runs-on: ubuntu-latest
permissions:
contents: read
packages: write
strategy:
matrix:
node-version: [21.x]
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Use Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v4
with:
node-version: ${{ matrix.node-version }}
# build, lint, test, test-run first, to fail early
- run: npm ci
- run: npm run lint
- run: npm test
- run: npm run start
# - name: Set up QEMU
# uses: docker/setup-qemu-action@v2
# - name: Set up Docker Buildx
# uses: docker/setup-buildx-action@v2
- name: Log in to the Container registry
uses: docker/login-action@v3
with:
registry: ${{ env.REGISTRY }}
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: package.json info
id: meta
uses: jaywcjlove/github-action-package@main
- name: preparing variales to be lowercase
run: |
echo IMAGE_REPOSITORY=$(echo ${{ github.repository }} | tr '[:upper:]' '[:lower:]') >> $GITHUB_ENV
- name: Build and push Docker image
uses: docker/build-push-action@v5
with:
context: .
push: true
tags: '${{ env.REGISTRY }}/${{ env.IMAGE_REPOSITORY }}:${{ env.BRANCH_NAME }},${{ env.REGISTRY }}/${{ env.IMAGE_REPOSITORY }}:${{ steps.meta.outputs.version }},${{ env.REGISTRY }}/${{ env.IMAGE_REPOSITORY }}:${{ env.COMMIT_SHA }},${{ env.REGISTRY }}/${{ env.IMAGE_REPOSITORY }}:latest'
# tags: ${{ steps.meta.outputs.tags }} #TAG from metadata-action
# labels: ${{ steps.meta.outputs.labels }} #TAG from metadata-action
# platforms: linux/amd64,linux/arm64
# - name: Trigger Re-Deploy Stage
# env:
# SECRET_UPDATE_URL: ${{ secrets.UPDATE_URL }}
# uses: fjogeleit/http-request-action@v1
# with:
# url: "${{ env.SECRET_UPDATE_URL }}"
# method: 'GET'
# if: env.SECRET_UPDATE_URL != null