MeshSync v0.8.0 #221
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Multi-Platform Build and Release | |
on: | |
release: | |
types: [published] | |
push: | |
tags: | |
- 'v*' | |
branches: | |
- 'master' | |
paths-ignore: | |
- 'docs/**' | |
# - '.github/**' | |
workflow_dispatch: | |
inputs: | |
release-ver: | |
description: 'Stable Release Version' | |
required: true | |
default: 'v' | |
stripped-release-ver: | |
description: 'Stripped Stable Release Version' | |
required: true | |
default: '' | |
release-channel: | |
description: 'Release Channel' | |
required: true | |
default: 'edge' | |
env: | |
GIT_VERSION: ${{github.event.inputs.release-ver}} | |
GIT_STRIPPED_VERSION: ${{github.event.inputs.stripped-release-ver}} | |
RELEASE_CHANNEL: ${{github.event.inputs.release-channel}} | |
GIT_TAG: ${{ github.event.release.tag_name }} | |
jobs: | |
print-inputs: | |
runs-on: ubuntu-22.04 | |
steps: | |
- run: | | |
echo "Dispatched GIT_VERSION: ${{github.event.inputs.release-ver}}" | |
echo " Dispatched GIT_STRIPPED_VERSION: ${{github.event.inputs.stripped-release-ver}}" | |
echo "Env RELEASE_CHANNEL: ${{env.RELEASE_CHANNEL}}" | |
echo "Env GIT_VERSION: ${{env.GIT_VERSION}}" | |
echo "Env GIT_STRIPPED_VERSION: ${{env.GIT_STRIPPED_VERSION}}" | |
echo "Env GIT_TAG: ${{ github.event.release.tag_name }}" | |
docker-build: | |
runs-on: ubuntu-22.04 | |
steps: | |
- | |
name: Checkout repo | |
uses: actions/checkout@main | |
- | |
name: Identify Release Values | |
if: "${{ github.event.inputs.release-ver}} != 'v' }}" | |
run: | | |
# GIT_REF=`git symbolic-ref HEAD` | |
if [[ $GIT_TAG = refs/tags* ]] | |
then | |
echo RELEASE_CHANNEL=stable >> $GITHUB_ENV | |
else | |
echo RELEASE_CHANNEL=edge >> $GITHUB_ENV | |
fi | |
echo "Release channel determined to be $RELEASE_CHANNEL" | |
LATEST_VERSION=$(git ls-remote --tags | tail -1 | cut -f2 | sed 's/refs\/tags\///g') >> $GITHUB_ENV | |
GIT_VERSION=$(git ls-remote --tags | tail -1 | cut -f2 | sed 's/refs\/tags\///g') >> $GITHUB_ENV | |
# GIT_VERSION=$(git describe --tags `git rev-list --tags --max-count=1` --always) | |
GIT_STRIPPED_VERSION=$(git ls-remote --tags | tail -1 | cut -f2 | sed 's/refs\/tags\///g' | cut -c2-) | |
echo "GIT_LATEST=$LATEST_VERSION" >> $GITHUB_ENV | |
echo "GIT_VERSION=$GIT_VERSION" >> $GITHUB_ENV | |
echo "GIT_STRIPPED_VERSION=$GIT_STRIPPED_VERSION" >> $GITHUB_ENV | |
shell: bash | |
- | |
name: Set up QEMU | |
uses: docker/setup-qemu-action@v1 | |
- | |
name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v1 | |
- | |
name: Docker Meta | |
id: meta | |
uses: docker/metadata-action@v3 | |
with: | |
images: ${{ secrets.IMAGE_NAME }} | |
flavor: | | |
latest=false | |
tags: | | |
type=raw,value=${{env.RELEASE_CHANNEL}}-{{sha}} | |
type=semver,pattern={{version}},value=${{env.GIT_STRIPPED_VERSION}} | |
type=raw,pattern={{version}},value=${{env.RELEASE_CHANNEL}}-${{env.GIT_VERSION}} | |
type=raw,value=${{env.RELEASE_CHANNEL}}-{{tag}},enable=${{ startsWith(github.ref, 'refs/tags/v') }} | |
type=raw,value=${{env.RELEASE_CHANNEL}}-latest | |
type=raw,value=${{env.RELEASE_CHANNEL}}-${{env.GIT_VERSION}},enable=${{ startsWith(github.ref, 'refs/tags/v') }} | |
- | |
name: Login to DockerHub | |
uses: docker/login-action@v2 | |
with: | |
username: ${{ secrets.DOCKER_USERNAME }} | |
password: ${{ secrets.DOCKER_PASSWORD }} | |
- | |
name: Build and Push | |
uses: docker/build-push-action@v2 | |
with: | |
context: "{{defaultContext}}" | |
push: true | |
build-args: | | |
GIT_STRIPPED_VERSION=${{env.GIT_STRIPPED_VERSION}} | |
GIT_VERSION=${{env.GIT_VERSION}} | |
RELEASE_CHANNEL=${{env.RELEASE_CHANNEL}} | |
tags: ${{ steps.meta.outputs.tags }} | |
platforms: linux/amd64,linux/arm64 | |
# - | |
# name: Docker Hub Description | |
# uses: peter-evans/dockerhub-description@v3 | |
# with: | |
# username: ${{ secrets.DOCKER_USERNAME }} | |
# password: ${{ secrets.DOCKER_PASSWORD }} | |
# repository: meshery/meshery-docker-extension | |
# readme-filepath: /install/docker-extension/README.md |