Skip to content

update filesize calc #342

update filesize calc

update filesize calc #342

Workflow file for this run

name: ci
# Version 1.0.0
# This workflow is triggered on push events to the repository
# Please find readme.md for the usage of this workflow
on:
push:
jobs:
PREPARE-job:
runs-on: ubuntu-latest
outputs:
dockerfile_name: ${{ steps.parse_path.outputs.dockerfile_name }}
platform_tag: ${{ steps.parse_path.outputs.platform_tag }}
date: ${{ steps.date.outputs.date }}
proceed_valid: ${{ steps.set_proceed_flag.outputs.proceed_valid }}
devmode: ${{ steps.set_proceed_flag.outputs.devmode }}
directory: ${{ steps.parse_path.outputs.directory }}
files: ${{ steps.changed_files.outputs.files }}
platform: ${{ steps.parse_path.outputs.platform }}
runner_label: ${{ steps.set_runner_label.outputs.runner_label }}
noscan: ${{ steps.set_proceed_flag.outputs.noscan }}
steps:
- name: Set default runner label
id: set_default_runner_label
run: |
echo "runner_label=ubuntu-latest" >> $GITHUB_OUTPUT
- name: Check required variables and secrets and set runner-default
id: check_vars_secrets
run: |
missing_vars=()
missing_secrets=()
# check Variables
if [ -z "${{ vars.DOCKERHUB_USERNAME }}" ]; then
missing_vars+=("DOCKERHUB_USERNAME")
fi
if [ -z "${{ vars.QUAYIO_USERNAME }}" ]; then
missing_vars+=("QUAYIO_USERNAME")
fi
if [ -z "${{ vars.ACACIA_BUCKETNAME }}" ]; then
missing_vars+=("ACACIA_BUCKETNAME")
fi
# check Secrets
if [ -z "${{ secrets.PAT_TOKEN }}" ]; then
missing_secrets+=("PAT_TOKEN")
fi
if [ -z "${{ secrets.DOCKERHUB_TOKEN }}" ]; then
missing_secrets+=("DOCKERHUB_TOKEN")
fi
if [ -z "${{ secrets.QUAYIO_TOKEN }}" ]; then
missing_secrets+=("QUAYIO_TOKEN")
fi
if [ -z "${{ secrets.ACACIA_ACCESS_KEY_ID }}" ]; then
missing_secrets+=("ACACIA_ACCESS_KEY_ID")
fi
if [ -z "${{ secrets.ACACIA_SECRET_ACCESS_KEY }}" ]; then
missing_secrets+=("ACACIA_SECRET_ACCESS_KEY")
fi
# If any missing variables or secrets, exit with error
if [ ${#missing_vars[@]} -ne 0 ] || [ ${#missing_secrets[@]} -ne 0 ]; then
echo "Some required variables or secrets are not set:"
if [ ${#missing_vars[@]} -ne 0 ]; then
echo "Missing Variables: ${missing_vars[@]}"
fi
if [ ${#missing_secrets[@]} -ne 0 ]; then
echo "Missing Secrets: ${missing_secrets[@]}"
fi
exit 1
else
echo "All required variables and secrets are set."
fi
- name: Checkout repository
uses: actions/checkout@v4
with:
fetch-depth: 2 # Ensure enough history is available
- name: Get changed files
id: changed_files
run: |
files=$(git diff --name-only ${{ github.event.before }} ${{ github.sha }} '*.dockerfile')
echo "Files changed: $files"
echo "files=$files"
echo "files<<EOF" >> $GITHUB_OUTPUT
echo "$files" >> $GITHUB_OUTPUT
echo "EOF" >> $GITHUB_OUTPUT
- name: Debug output of changed files
run: |
echo "Files from output: ${{ steps.changed_files.outputs.files }}"
- name: Set proceed flag
id: set_proceed_flag
run: |
changed_files="${{ steps.changed_files.outputs.files }}"
# Count files of modified Dockerfile
file_count=$(echo "$changed_files" | wc -l)
if [ "$file_count" -eq 0 ]; then
echo "No Dockerfile has been modified. Setting proceed_valid to false."
echo "proceed_valid=false" >> $GITHUB_OUTPUT
exit 0
elif [ "$file_count" -gt 1 ]; then
echo "Multiple Dockerfiles have been modified ($file_count files). Setting proceed_valid to false."
echo "proceed_valid=false" >> $GITHUB_OUTPUT
exit 0
fi
# Only ONE Dockerfile modified
file="$changed_files"
echo "Single Dockerfile modified: $file"
# check Dockerfile includes org.opencontainers.image.compilation=auto
if grep -q -E '^[^#]*LABEL\s+org\.opencontainers\.image\.compilation\s*=\s*auto' "$file"; then
echo "Dockerfile contains org.opencontainers.image.compilation=auto. Setting proceed_valid to true."
echo "proceed_valid=true" >> $GITHUB_OUTPUT
else
echo "Dockerfile does not contain org.opencontainers.image.compilation=auto. Setting proceed_valid to false."
echo "proceed_valid=false" >> $GITHUB_OUTPUT
fi
# check Dockerfile includes org.opencontainers.image.devmode=true
if grep -q -E '^[^#]*LABEL\s+org\.opencontainers\.image\.devmode\s*=\s*true' "$file"; then
echo "Dockerfile contains org.opencontainers.image.devmode=true. Setting devmode to true."
echo "devmode=true" >> $GITHUB_OUTPUT
else
echo "Dockerfile does not contain org.opencontainers.image.devmode=true. Setting devmode to false."
echo "devmode=false" >> $GITHUB_OUTPUT
fi
# check Dockerfile includes org.opencontainers.image.noscan=true
if grep -q -E '^[^#]*LABEL\s+org\.opencontainers\.image\.noscan\s*=\s*true' "$file"; then
echo "Dockerfile contains org.opencontainers.image.noscan=true. Setting trivy to noscan."
echo "noscan=true" >> $GITHUB_OUTPUT
else
echo "Dockerfile does not contain org.opencontainers.image.noscan=true. Setting trivy to default."
echo "noscan=false" >> $GITHUB_OUTPUT
fi
- name: Parse file path
if: steps.set_proceed_flag.outputs.proceed_valid == 'true'
id: parse_path
run: |
file="${{ steps.changed_files.outputs.files }}"
echo "File: $file"
dir=$(dirname "$file")
echo "Directory: $dir"
base=$(basename "$file")
echo "Base: $base"
dockerfile_name="${base%.*}"
echo "Dockerfile name: $dockerfile_name"
# Determine platform by checking file contents
if grep -q -E '^[^#]*LABEL\s+org\.opencontainers\.image\.arch\s*=\s*(arm|aarch64|arm64)' "$file"; then
platform="linux/arm64"
platform_tag="arm"
elif grep -q -E '^[^#]*LABEL\s+org\.opencontainers\.image\.arch\s*=\s*(x86|amd64|x86_64)' "$file"; then
platform="linux/amd64"
platform_tag="x86"
else
echo "No known architecture label found in $file. Exiting."
exit 1
fi
echo "Platform: $platform"
echo "Platform tag: $platform_tag"
echo "dockerfile_name=$dockerfile_name" >> $GITHUB_OUTPUT
echo "platform=$platform" >> $GITHUB_OUTPUT
echo "platform_tag=$platform_tag" >> $GITHUB_OUTPUT
echo "directory=$dir" >> $GITHUB_OUTPUT
exit 0
- name: Set current date
if: steps.set_proceed_flag.outputs.proceed_valid == 'true'
id: date
run: |
date_tag=$(date +'%m-%d')
echo "Date tag: $date_tag"
echo "date=$date_tag" >> $GITHUB_OUTPUT
- name: Determine runner label
if: steps.set_proceed_flag.outputs.proceed_valid == 'true'
id: determine_runner
uses: actions/github-script@v7
with:
github-token: ${{secrets.PAT_TOKEN}}
script: |
let runner_label = 'X64';
const platform = '${{ steps.parse_path.outputs.platform }}';
if (platform === 'linux/arm64') {
const runners = await github.paginate(
github.rest.actions.listSelfHostedRunnersForRepo,
{
owner: context.repo.owner,
repo: context.repo.repo,
}
);
console.log(`Total runners found: ${runners.length}`);
runners.forEach(runner => {
const labels = runner.labels.map(label => label.name);
console.log(`Runner ID: ${runner.id}, Name: ${runner.name}, Status: ${runner.status}, Labels: ${labels.join(', ')}`);
});
let found = false;
for (const runner of runners) {
if (runner.status === 'online') {
const labels = runner.labels.map(label => label.name);
if (labels.includes('ARM64')) {
runner_label = 'ARM64';
console.log(`Found online runner with label "ARM64": Runner ID ${runner.id}, Name ${runner.name}`);
found = true;
break;
}
}
}
if (found) {
console.log('Found online runner with label "ARM64"');
} else {
console.log('No online runner with label "ARM64" found, using default runner');
}
} else {
console.log('Platform is not linux/arm64, using default X64 runner');
}
core.setOutput('runner_label', runner_label);
- name: Overwrite runner label
id: set_runner_label
run: |
if [ -n "${{ steps.determine_runner.outputs.runner_label }}" ]; then
echo "runner_label=${{ steps.determine_runner.outputs.runner_label }}" >> $GITHUB_OUTPUT
else
echo "runner_label=${{ steps.set_default_runner_label.outputs.runner_label }}" >> $GITHUB_OUTPUT
fi
- name: Debug variables before build
if: steps.set_proceed_flag.outputs.proceed_valid == 'true'
run: |
echo "Context: ${{ github.workspace }}/${{ steps.parse_path.outputs.directory }}"
echo "File: ${{ github.workspace }}/${{ steps.changed_files.outputs.files }}"
echo "Tag: ${{ vars.DOCKERHUB_USERNAME }}/${{ steps.parse_path.outputs.dockerfile_name }}-${{ steps.parse_path.outputs.platform_tag }}:${{ steps.date.outputs.date }}"
echo "Platforms: ${{ steps.parse_path.outputs.platform }}"
echo "Runner label: ${{ steps.determine_runner.outputs.runner_label }}"
BUILD-job:
needs: PREPARE-job
runs-on: ${{ needs.PREPARE-job.outputs.runner_label }}
if: needs.PREPARE-job.outputs.proceed_valid == 'true'
steps:
- name: Print hostname
run: |
echo "Hostname: $(hostname)"
- name: Checkout repository
uses: actions/checkout@v4
with:
fetch-depth: 1 # As the runs-on machine maybe different from Build, re-checkout source code. Only the current commit is needed
- name: Set up QEMU
uses: docker/setup-qemu-action@v3
with:
platforms: ${{ needs.PREPARE-job.outputs.platform }}
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
with:
driver: docker-container
install: true
- name: Show current Buildx builders
run: docker buildx ls
- name: Enable BuildKit
run: |
echo ${{ needs.PREPARE-job.outputs.runner_label}}
echo "DOCKER_BUILDKIT=1" >> $GITHUB_ENV
- name: Check and set docker cache location
id: docker_cache_check
run: |
CACHE_DIR="$HOME/runner/docker-cache"
echo "CACHE_DIR=$CACHE_DIR"
if [ -d "$CACHE_DIR" ]; then
echo "Cache directory exists."
CACHE_SIZE=$(du -sh "$CACHE_DIR" | cut -f1)
echo "Cache directory size: $CACHE_SIZE"
else
echo "Cache directory does not exist. Creating..."
if sudo mkdir -p "$CACHE_DIR"; then
sudo chown $(whoami):$(id -gn) "$CACHE_DIR"
echo "Cache directory created successfully."
else
echo "Failed to create cache directory: $CACHE_DIR" >&2
exit 1
fi
fi
echo "HOME=$HOME"
echo "CACHELOC=$CACHE_DIR" >> $GITHUB_ENV
echo "CACHELOC is set to ${CACHE_DIR} ".
- name: Build Docker image locally, save to tar file and move to persistent storage
uses: docker/build-push-action@v6
if: needs.PREPARE-job.outputs.devmode != 'true'
with:
context: ${{ github.workspace }}/${{ needs.PREPARE-job.outputs.directory }}
file: ${{ github.workspace }}/${{ needs.PREPARE-job.outputs.files }}
tags: |
${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}:${{ needs.PREPARE-job.outputs.date }}
platforms: ${{ needs.PREPARE-job.outputs.platform }}
push: false
load: true
provenance: false
cache-from: type=local,src=${{env.CACHELOC}}
cache-to: type=local,dest=${{env.CACHELOC}},mode=max
# cache-from: type=gha
# cache-to: type=gha,mode=max
- name: Build Docker image locally, for development mode
env:
CACHELOC: ${{ env.CACHELOC }}
if: needs.PREPARE-job.outputs.devmode == 'true'
run: |
docker buildx build \
--progress plain \
--cache-from type=local,src=${CACHELOC} \
--cache-to type=local,dest=${CACHELOC},mode=max \
--provenance=false \
--load \
--platform ${{ needs.PREPARE-job.outputs.platform }} \
--file ${{ github.workspace }}/${{ needs.PREPARE-job.outputs.files }} \
--tag ${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}:${{ needs.PREPARE-job.outputs.date }} \
${{ github.workspace }}/${{ needs.PREPARE-job.outputs.directory }}
- name: Save Docker image to tar file
run: |
docker save -o ${GITHUB_WORKSPACE}/image.tar ${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}:${{ needs.PREPARE-job.outputs.date }}
echo "Docker image saved to ${GITHUB_WORKSPACE}/image.tar"
- name: Move image.tar to local persistent storage "$HOME/runner/artifacts"
run: |
sudo mkdir -p $HOME/runner/artifacts/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}
sudo chown -R $(whoami):$(id -gn) $HOME/runner/artifacts/
cp ${GITHUB_WORKSPACE}/image.tar $HOME/runner/artifacts/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}/image.tar
echo "Moved image.tar to $HOME/runner/artifacts/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}/image.tar"
SCAN-AND-REPORT-job:
needs: [BUILD-job, PREPARE-job]
runs-on: ${{ needs.PREPARE-job.outputs.runner_label }}
if: needs.PREPARE-job.outputs.proceed_valid == 'true' && needs.PREPARE-job.outputs.noscan != 'true'
steps:
- name: Print hostname
run: |
echo "Hostname: $(hostname)"
- name: Copy back persistent storage "$HOME/runner/artifacts" to current directory
run: |
if [ -f "$HOME/runner/artifacts/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}/image.tar" ]; then
echo "File already exists, skipping copy."
else
cp $HOME/runner/artifacts/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}/image.tar ${GITHUB_WORKSPACE}
echo "Copied image.tar from $HOME/runner/artifacts/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}/image.tar to ${GITHUB_WORKSPACE}"
fi
- name: Create Trivy report directory
run: mkdir -p ./trivy-reports
- name: Scan the Docker image with Trivy
uses: aquasecurity/trivy-action@master
with:
input: './image.tar'
format: 'table'
output: './trivy-reports/trivy-report-${{ needs.PREPARE-job.outputs.dockerfile_name }}.txt'
severity: 'MEDIUM,CRITICAL,HIGH'
- name: Add Trivy report to GitHub Actions summary
run: |
echo '## Trivy Scan Report for ${{ needs.PREPARE-job.outputs.dockerfile_name }}' >> $GITHUB_STEP_SUMMARY
cat ./trivy-reports/trivy-report-${{ needs.PREPARE-job.outputs.dockerfile_name }}.txt >> $GITHUB_STEP_SUMMARY
- name: Upload Trivy scan report
uses: actions/upload-artifact@v4
with:
name: trivy-report-${{ needs.PREPARE-job.outputs.dockerfile_name }}
path: ${{ github.workspace }}/trivy-reports/trivy-report-${{ needs.PREPARE-job.outputs.dockerfile_name}}.txt
PUSH-PRIV-job:
needs: [BUILD-job, PREPARE-job]
runs-on: ${{ needs.PREPARE-job.outputs.runner_label }}
if: needs.PREPARE-job.outputs.proceed_valid == 'true'
env:
BUCKET: ${{ vars.ACACIA_BUCKETNAME }} # BYO or pawsey0001-image-compilation if compile for project
DESTINATION_PATH: ${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}/${{ needs.PREPARE-job.outputs.date }}
steps:
- name: Print hostname and set approved label for deployment
id: set_approved_label
run: |
echo "Hostname: $(hostname)"
- name: Copy back persistent storage "$HOME/runner/artifacts" to current directory in case of running before scan
run: |
if [ -f "$HOME/runner/artifacts/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}/image.tar" ]; then
echo "File already exists, skipping copy."
else
cp $HOME/runner/artifacts/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}/image.tar ${GITHUB_WORKSPACE}
echo "Copied image.tar from $HOME/runner/artifacts/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}/image.tar to ${GITHUB_WORKSPACE}"
fi
- name: Setup rclone
uses: ./.github/actions/setup-rclone
with:
access_key_id: ${{ secrets.ACACIA_ACCESS_KEY_ID }}
secret_access_key: ${{ secrets.ACACIA_SECRET_ACCESS_KEY }}
endpoint: https://projects.pawsey.org.au
bucket: ${{ env.BUCKET }}
destination_path: ${{ env.DESTINATION_PATH }}
- name: Upload image tar to S3 with rclone
run: |
set -e
# calculate file size
FILE_SIZE=$(wc -c < "${{ github.workspace }}/image.tar")
echo "File size: $FILE_SIZE bytes"
# dynamically set rclone parameters based on file size: 500MB, 5G,others
if [ "$FILE_SIZE" -lt $((1024 * 1024 * 500)) ]; then
S3_CHUNK_SIZE="16M"
S3_UPLOAD_CONCURRENCY=4
MULTI_THREAD_STREAMS=2
elif [ "$FILE_SIZE" -lt $((1024 * 1024 * 5000)) ]; then
S3_CHUNK_SIZE="64M"
S3_UPLOAD_CONCURRENCY=8
MULTI_THREAD_STREAMS=4
else
S3_CHUNK_SIZE="128M"
S3_UPLOAD_CONCURRENCY=16
MULTI_THREAD_STREAMS=8
fi
echo "Using S3 chunk size: $S3_CHUNK_SIZE"
echo "Using S3 upload concurrency: $S3_UPLOAD_CONCURRENCY"
echo "Using multi-thread streams: $MULTI_THREAD_STREAMS"
# execute rclone copy
rclone copy ${{ github.workspace }}/image.tar pawsey0001:"${{ env.BUCKET }}/${{ env.DESTINATION_PATH }}/" \
--multi-thread-streams=$MULTI_THREAD_STREAMS \
--s3-chunk-size=$S3_CHUNK_SIZE \
--s3-upload-concurrency=$S3_UPLOAD_CONCURRENCY
- name: Login to Docker Hub
uses: docker/login-action@v3
with:
username: ${{ vars.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Load Docker image from image.tar
run: |
docker load -i ${GITHUB_WORKSPACE}/image.tar
- name: Tag Docker image for Dockerhub and Quay.IO
run: |
docker tag ${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}:${{ needs.PREPARE-job.outputs.date }} ${{ vars.DOCKERHUB_USERNAME }}/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}:${{ needs.PREPARE-job.outputs.date }}
- name: Push Docker image to Dockerhub after approval
run: |
docker push ${{ vars.DOCKERHUB_USERNAME }}/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}:${{ needs.PREPARE-job.outputs.date }}
- name: Remove Docker images
run: |
# Remove the main image
docker rmi ${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}:${{ needs.PREPARE-job.outputs.date }} || true
# Remove tagged images
docker rmi ${{ vars.DOCKERHUB_USERNAME }}/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}:${{ needs.PREPARE-job.outputs.date }} || true
CLEANUP-job:
needs: [APPROVE-PUSH-PUB-job,PUSH-PRIV-job, SCAN-AND-REPORT-job, BUILD-job, PREPARE-job]
if: always()
runs-on: ${{ needs.PREPARE-job.outputs.runner_label }}
steps:
- name: Clean-up
run: |
sudo rm -rf $HOME/runner/artifacts/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}
DEPLOY-job:
needs: [PUSH-PRIV-job,PREPARE-job]
runs-on: Ella
if: needs.PREPARE-job.outputs.platform_tag == 'arm'
env:
BUCKET: ${{ vars.ACACIA_BUCKETNAME }} # BYO or pawsey0001-image-compilation if compile for project
DESTINATION_PATH: ${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}/${{ needs.PREPARE-job.outputs.date }}
#environment:
# name: manual_approval
steps:
- name: Checkout repository
uses: actions/checkout@v4
with:
fetch-depth: 1 # As the runs-on machine maybe different from Build, re-checkout source code. Only the current commit is needed
- name: Setup rclone
uses: ./.github/actions/setup-rclone
with:
access_key_id: ${{ secrets.ACACIA_ACCESS_KEY_ID }}
secret_access_key: ${{ secrets.ACACIA_SECRET_ACCESS_KEY }}
endpoint: https://projects.pawsey.org.au
bucket: ${{ env.BUCKET }}
destination_path: ${{ env.DESTINATION_PATH }}
- name: Deploy ARM image to Ella
run: |
echo "Deploying ARM image to Ella"
echo "Hostname: $(hostname)"
echo "Deploying image: ${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}:${{ needs.PREPARE-job.outputs.date }}" to Ella
mkdir -p $MYSCRATCH/image/${{ needs.PREPARE-job.outputs.dockerfile_name }}/
rclone copy pawsey0001:"${{ env.BUCKET }}/${{ env.DESTINATION_PATH }}/image.tar" $MYSCRATCH/image/${{ needs.PREPARE-job.outputs.dockerfile_name }}/
- name: Convert to Singularity File
run: |
echo "Converting to Singularity File"
echo "Converting image: ${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}:${{ needs.PREPARE-job.outputs.date }}" to Singularity
source ~/.bashrc
singularity build --force $MYSCRATCH/image/${{ needs.PREPARE-job.outputs.dockerfile_name }}/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}.sif docker-archive://$MYSCRATCH/image/${{ needs.PREPARE-job.outputs.dockerfile_name }}/image.tar
APPROVE-PUSH-PUB-job:
needs: [BUILD-job, PREPARE-job]
runs-on: ${{ needs.PREPARE-job.outputs.runner_label }}
if: needs.PREPARE-job.outputs.proceed_valid == 'true'
environment:
name: manual_approval
steps:
- name: Print hostname and set approved label for deployment
id: set_approved_label
run: |
echo "Hostname: $(hostname)"
- name: Copy back persistent storage "$HOME/runner/artifacts" to current directory in case of running before scan
run: |
if [ -f "$HOME/runner/artifacts/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}/image.tar" ]; then
echo "File already exists, skipping copy."
else
cp $HOME/runner/artifacts/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}/image.tar ${GITHUB_WORKSPACE}
echo "Copied image.tar from $HOME/runner/artifacts/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}/image.tar to ${GITHUB_WORKSPACE}"
fi
- name: Login to quay Container Registry
uses: docker/login-action@v3
with:
registry: quay.io
username: ${{ vars.QUAYIO_USERNAME }}
password: ${{ secrets.QUAYIO_TOKEN }}
- name: Load Docker image from image.tar
run: |
docker load -i ${GITHUB_WORKSPACE}/image.tar
- name: Tag Docker image for Dockerhub and Quay.IO
run: |
docker tag ${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}:${{ needs.PREPARE-job.outputs.date }} quay.io/${{ vars.QUAYIO_USERNAME }}/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}:${{ needs.PREPARE-job.outputs.date }}
docker tag ${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}:${{ needs.PREPARE-job.outputs.date }} quay.io/pawsey/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}:${{ needs.PREPARE-job.outputs.date }}
- name: Push Docker image to Quay.IO after approval
if: needs.PREPARE-job.outputs.devmode != 'true'
run: |
docker push quay.io/${{ vars.QUAYIO_USERNAME }}/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}:${{ needs.PREPARE-job.outputs.date }}
docker push quay.io/pawsey/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}:${{ needs.PREPARE-job.outputs.date }}
- name: Remove Docker images
run: |
# Remove the main image
docker rmi ${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}:${{ needs.PREPARE-job.outputs.date }} || true
# Remove tagged images
docker rmi quay.io/${{ vars.QUAYIO_USERNAME }}/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}:${{ needs.PREPARE-job.outputs.date }} || true
docker rmi quay.io/pawsey/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}:${{ needs.PREPARE-job.outputs.date }} || true
# APPROVE-AND-DEPLOY-job:
# needs: [SCAN-AND-REPORT-job, PREPARE-job]
# runs-on: experiment
# if: needs.PREPARE-job.outputs.proceed_valid == 'true'
# strategy:
# matrix:
# task: [push-dockerhub, push-quay, upload-s3]
# env:
# BUCKET: pawsey0001-image-compilation
# DESTINATION_PATH: ${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}
# environment:
# name: manual_approval
# steps:
# - name: Copy back persistent storage "/home/runner/artifacts" to current directory
# run: |
# cp /home/runner/artifacts/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}/image.tar ${GITHUB_WORKSPACE}
# echo "Copied image.tar from /home/runner/artifacts/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}/image.tar to ${GITHUB_WORKSPACE}"
# - name: Load Docker image from image.tar and tag for dockerhub and quay.io
# run: |
# docker load -i ${GITHUB_WORKSPACE}/image.tar
# docker tag klinus/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}:${{ needs.PREPARE-job.outputs.date }} quay.io/klinus/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}:${{ needs.PREPARE-job.outputs.date }}
# - name: Login to Docker Hub
# if: matrix.task == 'push-dockerhub'
# uses: docker/login-action@v3
# with:
# username: ${{ vars.DOCKERHUB_USERNAME }}
# password: ${{ secrets.DOCKERHUB_TOKEN }}
# - name: Push Docker image to DockerHub
# if: matrix.task == 'push-dockerhub'
# run: |
# docker push klinus/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}:${{ needs.PREPARE-job.outputs.date }}
# - name: Login to Quay Container Registry
# if: matrix.task == 'push-quay'
# uses: docker/login-action@v3
# with:
# registry: quay.io
# username: ${{ vars.QUAYIO_USERNAME }}
# password: ${{ secrets.QUAYIO_TOKEN }}
# - name: Push Docker image to Quay.IO after approval
# if: matrix.task == 'push-quay'
# run: |
# docker push quay.io/klinus/${{ needs.PREPARE-job.outputs.dockerfile_name }}-${{ needs.PREPARE-job.outputs.platform_tag }}:${{ needs.PREPARE-job.outputs.date }}
# # Steps for uploading to S3 with rclone
# - name: Setup rclone
# if: matrix.task == 'upload-s3'
# uses: ./.github/actions/setup-rclone
# with:
# access_key_id: ${{ secrets.ACACIA_ACCESS_KEY_ID }}
# secret_access_key: ${{ secrets.ACACIA_SECRET_ACCESS_KEY }}
# endpoint: https://projects.pawsey.org.au
# bucket: ${{ env.BUCKET }}
# destination_path: ${{ env.DESTINATION_PATH }}
# - name: Upload image tar to S3 with rclone
# if: matrix.task == 'upload-s3'
# run: |
# set -e
# rclone copy ${{ github.workspace }}/image.tar pawsey0001:"${{ env.BUCKET }}/${{ env.DESTINATION_PATH }}/"