Skip to content

update sdk version

update sdk version #17

Workflow file for this run

name: Publish Docker
on:
push:
tags:
- "*"
workflow_dispatch:
inputs:
branch:
description: "Branch to run the action on"
default: "main"
required: true
jobs:
build_and_publish_platform_containers:
name: Build and publish platform containers
runs-on: ${{ matrix.os }}
permissions:
packages: write
strategy:
fail-fast: false
matrix:
os:
- warp-ubuntu-latest-x64-2x
- warp-ubuntu-latest-arm64-2x
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Set up QEMU
uses: docker/setup-qemu-action@v3
- name: Login to DockerHub
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Login to GitHub Container Registry
uses: docker/login-action@v3
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Build the docker image
env:
BUILD_PLATFORM: ${{ matrix.os == 'warp-ubuntu-latest-arm64-2x' && 'arm64' || 'amd64' }}
run: |
APP_VERSION="$(git name-rev --tags --name-only $(git rev-parse HEAD) | head -n 1 | sed 's/\^0//')"
GIT_SHA="$(git rev-parse HEAD)"
docker build \
-f ./docker/Dockerfile \
--progress=plain \
-t "unsend/unsend-$BUILD_PLATFORM:latest" \
-t "unsend/unsend-$BUILD_PLATFORM:$GIT_SHA" \
-t "unsend/unsend-$BUILD_PLATFORM:$APP_VERSION" \
-t "ghcr.io/unsend-dev/unsend-$BUILD_PLATFORM:latest" \
-t "ghcr.io/unsend-dev/unsend-$BUILD_PLATFORM:$GIT_SHA" \
-t "ghcr.io/unsend-dev/unsend-$BUILD_PLATFORM:$APP_VERSION" \
.
- name: Push the docker image to DockerHub
run: docker push --all-tags "unsend/unsend-$BUILD_PLATFORM"
env:
BUILD_PLATFORM: ${{ matrix.os == 'warp-ubuntu-latest-arm64-2x' && 'arm64' || 'amd64' }}
- name: Push the docker image to GitHub Container Registry
run: docker push --all-tags "ghcr.io/unsend-dev/unsend-$BUILD_PLATFORM"
env:
BUILD_PLATFORM: ${{ matrix.os == 'warp-ubuntu-latest-arm64-2x' && 'arm64' || 'amd64' }}
create_and_publish_manifest:
name: Create and publish manifest
runs-on: ubuntu-latest
permissions:
packages: write
needs: build_and_publish_platform_containers
steps:
- name: Checkout
uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Login to DockerHub
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Login to GitHub Container Registry
uses: docker/login-action@v3
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Create and push DockerHub manifest
run: |
APP_VERSION="$(git name-rev --tags --name-only $(git rev-parse HEAD) | head -n 1 | sed 's/\^0//')"
GIT_SHA="$(git rev-parse HEAD)"
docker manifest create \
unsend/unsend:latest \
--amend unsend/unsend-amd64:latest \
--amend unsend/unsend-arm64:latest \
docker manifest create \
unsend/unsend:$GIT_SHA \
--amend unsend/unsend-amd64:$GIT_SHA \
--amend unsend/unsend-arm64:$GIT_SHA \
docker manifest create \
unsend/unsend:$APP_VERSION \
--amend unsend/unsend-amd64:$APP_VERSION \
--amend unsend/unsend-arm64:$APP_VERSION \
docker manifest push unsend/unsend:latest
docker manifest push unsend/unsend:$GIT_SHA
docker manifest push unsend/unsend:$APP_VERSION
- name: Create and push Github Container Registry manifest
run: |
APP_VERSION="$(git name-rev --tags --name-only $(git rev-parse HEAD) | head -n 1 | sed 's/\^0//')"
GIT_SHA="$(git rev-parse HEAD)"
docker manifest create \
ghcr.io/unsend-dev/unsend:latest \
--amend ghcr.io/unsend-dev/unsend-amd64:latest \
--amend ghcr.io/unsend-dev/unsend-arm64:latest \
docker manifest create \
ghcr.io/unsend-dev/unsend:$GIT_SHA \
--amend ghcr.io/unsend-dev/unsend-amd64:$GIT_SHA \
--amend ghcr.io/unsend-dev/unsend-arm64:$GIT_SHA \
docker manifest create \
ghcr.io/unsend-dev/unsend:$APP_VERSION \
--amend ghcr.io/unsend-dev/unsend-amd64:$APP_VERSION \
--amend ghcr.io/unsend-dev/unsend-arm64:$APP_VERSION \
docker manifest push ghcr.io/unsend-dev/unsend:latest
docker manifest push ghcr.io/unsend-dev/unsend:$GIT_SHA
docker manifest push ghcr.io/unsend-dev/unsend:$APP_VERSION