check if docker image exist #193
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: Concordium desktop wallet release | |
on: | |
push: | |
branches: | |
- 'ekw/SRE-1001/release-desktop-wallet' | |
tags: | |
- 'desktop-wallet/*.*.*-stagenet' | |
- 'desktop-wallet/*.*.*-testnet' | |
- 'desktop-wallet/*.*.*-mainnet' | |
env: | |
BASE_IMAGE_VERSION: "rust-1.74.1_ghc-9.6.4" | |
STATIC_NODE_BINARY_IMAGE_NAME: 'static-node-binaries' | |
AWS_ROLE_TO_ASSUME: "arn:aws:iam::192549843005:role/github_concordium-desktop-wallet" | |
S3_BUCKET: "s3://desktopwallet.concordium.com" | |
ECR_REPO: "192549843005.dkr.ecr.eu-west-1.amazonaws.com/concordium/desktop-wallet-ci" | |
WASM-PACK_VERSION: "v0.9.1" | |
NODE_VERSION: "14.16.0" | |
permissions: | |
id-token: write | |
contents: read | |
jobs: | |
build-ci-image: | |
runs-on: ubuntu-latest | |
outputs: | |
access_key: ${{ steps.login-ecr.outputs.docker_username_192549843005_dkr_ecr_eu_west_1_amazonaws_com }} | |
secret_key: ${{ steps.login-ecr.outputs.docker_password_192549843005_dkr_ecr_eu_west_1_amazonaws_com }} | |
CONTAINER_TAG: ${{ steps.version_check.outputs.CONTAINER_TAG }} | |
VERSION: ${{ steps.version_check.outputs.VERSION }} | |
TARGET_NET: ${{ steps.target_net.outputs.TARGET_NET }} | |
environment: release | |
steps: | |
- name: Assume role | |
uses: aws-actions/configure-aws-credentials@v4 | |
id: creds | |
with: | |
aws-region: "eu-west-1" | |
role-to-assume: ${{ env.AWS_ROLE_TO_ASSUME }} | |
role-session-name: ReleaseDesktopWalletSession | |
mask-aws-account-id: false | |
- name: Login to Amazon ECR | |
id: login-ecr | |
uses: aws-actions/amazon-ecr-login@v2 | |
with: | |
mask-password: false | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
with: | |
submodules: recursive | |
ref: ${{ github.ref_name }} | |
- name: Set target net if correctly formatted | |
id: target_net | |
env: | |
TAG: 'desktop-wallet/1.7.4-stagenet' #${{ github.ref_name }} | |
run: | | |
TARGET_NET=${TAG##desktop-wallet/*-} | |
echo "$TARGET_NET" | |
if [[ $TARGET_NET != "stagenet" ]] && [[ $TARGET_NET != "testnet" ]] && [[ $TARGET_NET != "mainnet" ]]; then | |
echo "::error:: Tag does not contain target net" | |
exit 1 | |
fi | |
echo "TARGET_NET=$TARGET_NET" >> $GITHUB_OUTPUT | |
- name: Verify version | |
id: version_check | |
env: | |
TAG: 'desktop-wallet/1.7.4-stagenet' #${{ github.ref_name}} | |
run: | | |
# Extract version number | |
VERSION=$(jq '.version' -r app/package.json) | |
TAG_VERSION_NET=${TAG##*/} | |
TAG_VERSION=${TAG_VERSION_NET%%-*} | |
if [ "$VERSION" != "$TAG_VERSION" ]; then | |
echo "::error:: Tag version is not correct. Tag version: $TAG_VERSION version from package.json: $VERSION" | |
exit 1 | |
fi | |
aws ecr describe-images --registry-id "192549843005" --repository-name "concordium/desktop-wallet-ci" --region eu-west-1 --image-ids=imageTag=$VERSION-test | |
EC=$? | |
echo "EXIT_CODE=$EC" >> $GITHUB_ENV | |
echo "VERSION=$VERSION-test" >> $GITHUB_OUTPUT | |
echo "CONTAINER_TAG=${{ env.ECR_REPO }}:$VERSION-test" >> $GITHUB_OUTPUT | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v3 | |
- name: build ci image | |
if: ${{ env.EXIT_CODE == 254 }} | |
uses: docker/build-push-action@v6 | |
with: | |
push: true | |
tags: "${{ steps.version_check.outputs.CONTAINER_TAG }}" | |
context: '.' | |
file: 'scripts/desktop-wallet-ci.Dockerfile' | |
cache-from: type=gha | |
cache-to: type=gha,mode=max | |
build-args: | | |
BASE_VERSION=${{ env.BASE_IMAGE_VERSION }} | |
NODE_VERSION=${{ env.NODE_VERSION }} | |
release-desktop-wallet-linux: | |
environment: release | |
needs: build-ci-image | |
runs-on: ubuntu-latest | |
container: | |
image: "${{needs.build-ci-image.outputs.CONTAINER_TAG}}" | |
credentials: | |
username: ${{needs.build-ci-image.outputs.access_key}} | |
password: ${{needs.build-ci-image.outputs.secret_key}} | |
options: -u root | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
with: | |
submodules: recursive | |
ref: ${{ github.ref_name }} | |
- name: Login to Amazon ECR | |
uses: aws-actions/configure-aws-credentials@v4 | |
id: creds | |
with: | |
aws-region: "eu-west-1" | |
role-to-assume: ${{ env.AWS_ROLE_TO_ASSUME }} | |
role-session-name: ReleaseDesktopWalletSession | |
mask-aws-account-id: false | |
- name: Generate output folder | |
run: | | |
set +e | |
TARGET_NET=${{ needs.build-ci-image.outputs.TARGET_NET}} | |
VERSION=${{ needs.build-ci-image.outputs.VERSION }} | |
OUT_FOLDER_PATH="${{ env.S3_BUCKET }}/${VERSION}/${TARGET_NET}" | |
echo "OUT_FOLDER_PATH=$OUT_FOLDER_PATH" >> $GITHUB_ENV | |
- name: Check if Executable exist | |
run: | | |
set +e | |
aws s3 ls "${{ env.OUT_FOLDER_PATH }}/latest-linux.yml" | |
EC=$? | |
if [ $EC -eq 0 ]; then | |
echo "::error:: file file already exist" | |
exit 1 | |
elif [ $EC -ne 1 ]; then | |
echo "::error:: $EC" | |
exit 1 | |
fi | |
- name: Output dependency versions | |
run: | | |
rustup default stable | |
echo "::notice::node version: $(node --version)" | |
echo "::notice::npm version: $(npm --version)" | |
echo "::notice::yarn version: $(yarn --version)" | |
echo "::notice::python version: $(python --version)" | |
echo "::notice::rustup version: $(rustup show)" | |
echo "::notice::wasm-pack version: $(wasm-pack --version)" | |
- name: Build and publish | |
run: | | |
set +e | |
yarn | |
yarn package | |
aws s3 cp --recursive release/ ${{ env.OUT_FOLDER_PATH }} --exclude linux-unpacked/* --exclude builder-debug.yml --grants read=uri=http://acs.amazonaws.com/groups/global/AllUsers | |
#using windows-2019 to be able to use visual studio 2019, newer versions do not support older versions of node.js | |
release-desktop-wallet-windows: | |
runs-on: windows-2019 | |
environment: release | |
needs: build-ci-image | |
steps: | |
- name: aws creds | |
uses: aws-actions/configure-aws-credentials@v4 | |
id: creds | |
with: | |
aws-region: "eu-west-1" | |
role-to-assume: ${{ env.AWS_ROLE_TO_ASSUME }} | |
role-session-name: ReleaseDesktopWalletSession | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
with: | |
submodules: recursive | |
ref: ${{ github.ref_name }} | |
- name: Install dependencies | |
uses: jetli/[email protected] | |
with: | |
version: ${{ env.WASM-PACK_VERSION }} | |
- name: install node | |
uses: actions/setup-node@v4 | |
with: | |
node-version: ${{ env.NODE_VERSION }} | |
- name: Generate output folder | |
shell: bash | |
run: | | |
set +e | |
TARGET_NET=${{ needs.build-ci-image.outputs.TARGET_NET}} | |
VERSION=${{ needs.build-ci-image.outputs.VERSION }} | |
OUT_FOLDER_PATH="${{ env.S3_BUCKET }}/${VERSION}/${TARGET_NET}" | |
echo "OUT_FOLDER_PATH=$OUT_FOLDER_PATH" >> $GITHUB_ENV | |
- name: Check if executable exist | |
shell: bash | |
run: | | |
set +e | |
aws s3 ls "${{ env.OUT_FOLDER_PATH }}/latest.yml" | |
EC=$? | |
echo $EC | |
if [ $EC -eq 0 ]; then | |
echo "::error:: file already exist" | |
exit 1 | |
elif [ $EC -ne 1 ]; then | |
echo "::error:: $EC" | |
exit 1 | |
fi | |
- name: Output dependency versions | |
shell: bash | |
run: | | |
echo "::notice::node version: $(node --version)" | |
echo "::notice::npm version: $(npm --version)" | |
echo "::notice::yarn version: $(yarn --version)" | |
echo "::notice::python version: $(python --version)" | |
echo "::notice::rustup version: $(rustup show)" | |
echo "::notice::wasm-pack version: $(wasm-pack --version)" | |
- name: Build and push desktop wallet | |
shell: bash | |
run: | | |
yarn --network-timeout 1000000 | |
yarn package-win-no-sign | |
aws s3 cp --recursive release/ ${{ env.OUT_FOLDER_PATH }} --exclude win-unpacked/* --exclude builder-debug.yml --exclude *.blockmap --grants read=uri=http://acs.amazonaws.com/groups/global/AllUsers |