Skip to content

chore: update build workflow to trigger on v1 branch instead of beta #1485

chore: update build workflow to trigger on v1 branch instead of beta

chore: update build workflow to trigger on v1 branch instead of beta #1485

Workflow file for this run

name: Build & Publish Docker Images
on:
push:
branches:
- v1
jobs:
#
# # # # # # # # # # # # # # # # # # # # #
# # # # # # # # # # # # # # # # # # # # #
api-server:
name: server (NodeJS)
runs-on: ubuntu-latest
strategy:
fail-fast: false
permissions:
contents: read
packages: write
steps:
- name: Set module key
run: |
echo "MODULE_KEY=server" >> $GITHUB_ENV
- name: Checkout repository
uses: actions/checkout@main
- name: Calculate module SHA256 hash
run: |
find "./${{ env.MODULE_KEY }}" -type f -print0 | sort -z | xargs -0 sha256sum | sha256sum | cut -d' ' -f1 > ${{ env.MODULE_KEY }}.hash
echo "SHA256_HASH=$(cat ${{ env.MODULE_KEY }}.hash)" >> $GITHUB_ENV
- name: Fetch hash cache
uses: actions/cache@v4
id: cache
with:
path: ${{ env.MODULE_KEY }}.hash
key: ${{ github.ref_name }}-${{ env.MODULE_KEY }}-${{ env.SHA256_HASH }}
- name: Login to GitHub Container Registry
if: steps.cache.outputs.cache-hit != 'true'
uses: docker/login-action@master
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Build and Push Docker Image
if: steps.cache.outputs.cache-hit != 'true'
uses: docker/build-push-action@master
with:
push: true
context: ./${{ env.MODULE_KEY }}
file: ./${{ env.MODULE_KEY }}/Dockerfile
tags: ghcr.io/carrismetropolitana/api-${{ env.MODULE_KEY }}:${{ github.ref_name }}
# # # # # # # # # # # # # # # # # # # # #
# # # # # # # # # # # # # # # # # # # # #
api-switch:
name: switch (NodeJS)
runs-on: ubuntu-latest
strategy:
fail-fast: false
permissions:
contents: read
packages: write
steps:
- name: Set module key
run: |
echo "MODULE_KEY=switch" >> $GITHUB_ENV
- name: Checkout repository
uses: actions/checkout@main
- name: Calculate module SHA256 hash
run: |
find "./${{ env.MODULE_KEY }}" -type f -print0 | sort -z | xargs -0 sha256sum | sha256sum | cut -d' ' -f1 > ${{ env.MODULE_KEY }}.hash
echo "SHA256_HASH=$(cat ${{ env.MODULE_KEY }}.hash)" >> $GITHUB_ENV
- name: Fetch hash cache
uses: actions/cache@v4
id: cache
with:
path: ${{ env.MODULE_KEY }}.hash
key: ${{ github.ref_name }}-${{ env.MODULE_KEY }}-${{ env.SHA256_HASH }}
- name: Login to GitHub Container Registry
if: steps.cache.outputs.cache-hit != 'true'
uses: docker/login-action@master
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Build and Push Docker Image
if: steps.cache.outputs.cache-hit != 'true'
uses: docker/build-push-action@master
with:
push: true
context: ./${{ env.MODULE_KEY }}
file: ./${{ env.MODULE_KEY }}/Dockerfile
tags: ghcr.io/carrismetropolitana/api-${{ env.MODULE_KEY }}:${{ github.ref_name }}
# # # # # # # # # # # # # # # # # # # # #
# # # # # # # # # # # # # # # # # # # # #
api-sync-alerts:
name: sync-alerts (NodeJS)
runs-on: ubuntu-latest
strategy:
fail-fast: false
permissions:
contents: read
packages: write
steps:
- name: Set module key
run: |
echo "MODULE_KEY=sync-alerts" >> $GITHUB_ENV
- name: Checkout repository
uses: actions/checkout@main
- name: Calculate module SHA256 hash
run: |
find "./${{ env.MODULE_KEY }}" -type f -print0 | sort -z | xargs -0 sha256sum | sha256sum | cut -d' ' -f1 > ${{ env.MODULE_KEY }}.hash
echo "SHA256_HASH=$(cat ${{ env.MODULE_KEY }}.hash)" >> $GITHUB_ENV
- name: Fetch hash cache
uses: actions/cache@v4
id: cache
with:
path: ${{ env.MODULE_KEY }}.hash
key: ${{ github.ref_name }}-${{ env.MODULE_KEY }}-${{ env.SHA256_HASH }}
- name: Login to GitHub Container Registry
if: steps.cache.outputs.cache-hit != 'true'
uses: docker/login-action@master
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Build and Push Docker Image
if: steps.cache.outputs.cache-hit != 'true'
uses: docker/build-push-action@master
with:
push: true
context: ./${{ env.MODULE_KEY }}
file: ./${{ env.MODULE_KEY }}/Dockerfile
tags: ghcr.io/carrismetropolitana/api-${{ env.MODULE_KEY }}:${{ github.ref_name }}
# # # # # # # # # # # # # # # # # # # # #
# # # # # # # # # # # # # # # # # # # # #
api-sync-datasets:
name: sync-datasets (NodeJS)
runs-on: ubuntu-latest
strategy:
fail-fast: false
permissions:
contents: read
packages: write
steps:
- name: Set module key
run: |
echo "MODULE_KEY=sync-datasets" >> $GITHUB_ENV
- name: Checkout repository
uses: actions/checkout@main
- name: Calculate module SHA256 hash
run: |
find "./${{ env.MODULE_KEY }}" -type f -print0 | sort -z | xargs -0 sha256sum | sha256sum | cut -d' ' -f1 > ${{ env.MODULE_KEY }}.hash
echo "SHA256_HASH=$(cat ${{ env.MODULE_KEY }}.hash)" >> $GITHUB_ENV
- name: Fetch hash cache
uses: actions/cache@v4
id: cache
with:
path: ${{ env.MODULE_KEY }}.hash
key: ${{ github.ref_name }}-${{ env.MODULE_KEY }}-${{ env.SHA256_HASH }}
- name: Login to GitHub Container Registry
if: steps.cache.outputs.cache-hit != 'true'
uses: docker/login-action@master
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Build and Push Docker Image
if: steps.cache.outputs.cache-hit != 'true'
uses: docker/build-push-action@master
with:
push: true
context: ./${{ env.MODULE_KEY }}
file: ./${{ env.MODULE_KEY }}/Dockerfile
tags: ghcr.io/carrismetropolitana/api-${{ env.MODULE_KEY }}:${{ github.ref_name }}
# # # # # # # # # # # # # # # # # # # # #
# # # # # # # # # # # # # # # # # # # # #
api-sync-metrics:
name: sync-metrics (NodeJS)
runs-on: ubuntu-latest
strategy:
fail-fast: false
permissions:
contents: read
packages: write
steps:
- name: Set module key
run: |
echo "MODULE_KEY=sync-metrics" >> $GITHUB_ENV
- name: Checkout repository
uses: actions/checkout@main
- name: Calculate module SHA256 hash
run: |
find "./${{ env.MODULE_KEY }}" -type f -print0 | sort -z | xargs -0 sha256sum | sha256sum | cut -d' ' -f1 > ${{ env.MODULE_KEY }}.hash
echo "SHA256_HASH=$(cat ${{ env.MODULE_KEY }}.hash)" >> $GITHUB_ENV
- name: Fetch hash cache
uses: actions/cache@v4
id: cache
with:
path: ${{ env.MODULE_KEY }}.hash
key: ${{ github.ref_name }}-${{ env.MODULE_KEY }}-${{ env.SHA256_HASH }}
- name: Login to GitHub Container Registry
if: steps.cache.outputs.cache-hit != 'true'
uses: docker/login-action@master
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Build and Push Docker Image
if: steps.cache.outputs.cache-hit != 'true'
uses: docker/build-push-action@master
with:
push: true
context: ./${{ env.MODULE_KEY }}
file: ./${{ env.MODULE_KEY }}/Dockerfile
tags: ghcr.io/carrismetropolitana/api-${{ env.MODULE_KEY }}:${{ github.ref_name }}
# # # # # # # # # # # # # # # # # # # # #
# # # # # # # # # # # # # # # # # # # # #
api-sync-network:
name: sync-network (NodeJS)
runs-on: ubuntu-latest
strategy:
fail-fast: false
permissions:
contents: read
packages: write
steps:
- name: Set module key
run: |
echo "MODULE_KEY=sync-network" >> $GITHUB_ENV
- name: Checkout repository
uses: actions/checkout@main
- name: Calculate module SHA256 hash
run: |
find "./${{ env.MODULE_KEY }}" -type f -print0 | sort -z | xargs -0 sha256sum | sha256sum | cut -d' ' -f1 > ${{ env.MODULE_KEY }}.hash
echo "SHA256_HASH=$(cat ${{ env.MODULE_KEY }}.hash)" >> $GITHUB_ENV
- name: Fetch hash cache
uses: actions/cache@v4
id: cache
with:
path: ${{ env.MODULE_KEY }}.hash
key: ${{ github.ref_name }}-${{ env.MODULE_KEY }}-${{ env.SHA256_HASH }}
- name: Login to GitHub Container Registry
if: steps.cache.outputs.cache-hit != 'true'
uses: docker/login-action@master
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Build and Push Docker Image
if: steps.cache.outputs.cache-hit != 'true'
uses: docker/build-push-action@master
with:
push: true
context: ./${{ env.MODULE_KEY }}
file: ./${{ env.MODULE_KEY }}/Dockerfile
tags: ghcr.io/carrismetropolitana/api-${{ env.MODULE_KEY }}:${{ github.ref_name }}
# # # # # # # # # # # # # # # # # # # # #
# # # # # # # # # # # # # # # # # # # # #
api-sync-stores:
name: sync-stores (NodeJS)
runs-on: ubuntu-latest
strategy:
fail-fast: false
permissions:
contents: read
packages: write
steps:
- name: Set module key
run: |
echo "MODULE_KEY=sync-stores" >> $GITHUB_ENV
- name: Checkout repository
uses: actions/checkout@main
- name: Calculate module SHA256 hash
run: |
find "./${{ env.MODULE_KEY }}" -type f -print0 | sort -z | xargs -0 sha256sum | sha256sum | cut -d' ' -f1 > ${{ env.MODULE_KEY }}.hash
echo "SHA256_HASH=$(cat ${{ env.MODULE_KEY }}.hash)" >> $GITHUB_ENV
- name: Fetch hash cache
uses: actions/cache@v4
id: cache
with:
path: ${{ env.MODULE_KEY }}.hash
key: ${{ github.ref_name }}-${{ env.MODULE_KEY }}-${{ env.SHA256_HASH }}
- name: Login to GitHub Container Registry
if: steps.cache.outputs.cache-hit != 'true'
uses: docker/login-action@master
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Build and Push Docker Image
if: steps.cache.outputs.cache-hit != 'true'
uses: docker/build-push-action@master
with:
push: true
context: ./${{ env.MODULE_KEY }}
file: ./${{ env.MODULE_KEY }}/Dockerfile
tags: ghcr.io/carrismetropolitana/api-${{ env.MODULE_KEY }}:${{ github.ref_name }}
# # # # # # # # # # # # # # # # # # # # #
# # # # # # # # # # # # # # # # # # # # #
api-sync-vehicles:
name: sync-vehicles (NodeJS)
runs-on: ubuntu-latest
strategy:
fail-fast: false
permissions:
contents: read
packages: write
steps:
- name: Set module key
run: |
echo "MODULE_KEY=sync-vehicles" >> $GITHUB_ENV
- name: Checkout repository
uses: actions/checkout@main
- name: Calculate module SHA256 hash
run: |
find "./${{ env.MODULE_KEY }}" -type f -print0 | sort -z | xargs -0 sha256sum | sha256sum | cut -d' ' -f1 > ${{ env.MODULE_KEY }}.hash
echo "SHA256_HASH=$(cat ${{ env.MODULE_KEY }}.hash)" >> $GITHUB_ENV
- name: Fetch hash cache
uses: actions/cache@v4
id: cache
with:
path: ${{ env.MODULE_KEY }}.hash
key: ${{ github.ref_name }}-${{ env.MODULE_KEY }}-${{ env.SHA256_HASH }}
- name: Login to GitHub Container Registry
if: steps.cache.outputs.cache-hit != 'true'
uses: docker/login-action@master
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Build and Push Docker Image
if: steps.cache.outputs.cache-hit != 'true'
uses: docker/build-push-action@master
with:
push: true
context: ./${{ env.MODULE_KEY }}
file: ./${{ env.MODULE_KEY }}/Dockerfile
tags: ghcr.io/carrismetropolitana/api-${{ env.MODULE_KEY }}:${{ github.ref_name }}