Skip to content

Build and Push Docker Images on Tag #8

Build and Push Docker Images on Tag

Build and Push Docker Images on Tag #8

Workflow file for this run

name: Build and Push Docker Images on Tag
on:
push:
tags:
- "v*.*.*"
jobs:
build-and-push:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up QEMU and Docker Buildx
uses: docker/setup-qemu-action@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Log in to GitHub Container Registry (GHCR)
uses: docker/login-action@v3
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Expose GH Runtime
uses: crazy-max/ghaction-github-runtime@v3
- name: Build and Push Docker Images
run: |
TAG=${GITHUB_REF#refs/tags/} make build_and_push_images
env:
REGISTRY: ghcr.io
ORG: ${{ github.repository_owner }}
REPO: ${{ github.event.repository.name }}
GITHUB_WORKFLOW: ${{ github.workflow }}
build-tauri:
runs-on: [macos-latest]
permissions:
contents: write
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Rust setup
uses: dtolnay/rust-toolchain@stable
- name: Rust Cache
uses: swatinem/rust-cache@v2
with:
workspaces: "./tauri/src-tauri"
- name: Set up Nodejs
uses: actions/setup-node@v4
with:
node-version: "lts/*"
- name: Install Frontend deps
run: cd tauri && npm install
- name: Populate key
run: |
echo "${{ secrets.APPLE_API_KEY_B64 }}"|base64 --decode > ./apple.p8
- name: get release version
id: get_release_version
run: echo "TAG=${GITHUB_REF#refs/tags/}" >> $GITHUB_ENV
- name: get release id
id: get_release_id
uses: actions/github-script@v7
with:
script: |
const release = await github.rest.repos.getReleaseByTag({
owner: context.repo.owner,
repo: context.repo.repo,
tag: process.env.TAG
});
echo "RELEASE_ID=${release.data.id}" >> $GITHUB_ENV
- name: Build the app
uses: tauri-apps/tauri-action@v0
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
APPLE_API_ISSUER: ${{ secrets.APPLE_API_ISSUER }}
APPLE_API_KEY: ${{ secrets.APPLE_API_KEY }}
APPLE_API_KEY_PATH: ./apple.p8
APPLE_CERTIFICATE: ${{ secrets.APPLE_CERTIFICATE }}
APPLE_CERTIFICATE_PASSWORD: ${{ secrets.APPLE_CERTIFICATE_PASSWORD }}
APPLE_TEAM_ID: ${{ secrets.APPLE_TEAM_ID }}
APPLE_SIGNING_IDENTITY: ${{ secrets.APPLE_SIGNING_IDENTITY }}
APPLE_ID: ${{ secrets.APPLE_ID }}
APPLE_PASSWORD: ${{ secrets.APPLE_PASSWORD }}
with:
releaseId: ${process.env.RELEASE_ID}
args: --target universal-apple-darwin
projectPath: ./tauri