Skip to content

Enhancement: Determine composer version once #41

Enhancement: Determine composer version once

Enhancement: Determine composer version once #41

Workflow file for this run

name: Docker - v1
on:
pull_request: null
push:
paths:
- .github/workflows/v1.yaml
- '1.10/**'
env:
AWS_REGION: us-east-1
ECR_REPO: public.ecr.aws/u0u1j5s3/composer
jobs:
build:
name: Build v1.10
runs-on: ubuntu-latest
timeout-minutes: 20
defaults:
run:
working-directory: '1.10'
steps:
- uses: actions/checkout@v4
- name: Determine composer version from Dockerfile
working-directory: ${{ matrix.version }}
run: |
echo "COMPOSER_VERSION_MAJOR=$(grep -oP 'COMPOSER_VERSION \d+\.\d+\.\d+' Dockerfile | sed '/COMPOSER_VERSION /s///' | grep -oP '^\d+')" >> $GITHUB_ENV
echo "COMPOSER_VERSION_MAJOR_MINOR=$(grep -oP 'COMPOSER_VERSION \d+\.\d+\.\d+' Dockerfile | sed '/COMPOSER_VERSION /s///' | grep -oP '^\d+\.\d+')" >> $GITHUB_ENV
echo "COMPOSER_VERSION_MAJOR_MINOR_PATCH=$(grep -oP 'COMPOSER_VERSION \d+\.\d+\.\d+' Dockerfile | sed '/COMPOSER_VERSION /s///')" >> $GITHUB_ENV
# Build full image: binary with runtime
- name: Build full image
run: |
docker build \
--pull \
--no-cache \
--target binary-with-runtime \
--tag composer/composer:${{ env.COMPOSER_VERSION_MAJOR }} \
--tag composer/composer:${{ env.COMPOSER_VERSION_MAJOR_MINOR }} \
--tag composer/composer:${{ env.COMPOSER_VERSION_MAJOR_MINOR_PATCH }} \
.
# Build low-size image with binary only
- name: Build binary-only image
run: |
docker build \
--pull \
--no-cache \
--target standalone-binary \
--tag composer/composer:${{ env.COMPOSER_VERSION_MAJOR }}-bin \
--tag composer/composer:${{ env.COMPOSER_VERSION_MAJOR_MINOR }}-bin \
--tag composer/composer:${{ env.COMPOSER_VERSION_MAJOR_MINOR_PATCH }}-bin \
.
- name: Login to Docker Hub
if: github.ref == 'refs/heads/main'
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_PASSWORD }}
- name: Push tag(s) to Docker Hub
if: github.ref == 'refs/heads/main'
run: |
docker push composer/composer:${{ env.COMPOSER_VERSION_MAJOR }}
docker push composer/composer:${{ env.COMPOSER_VERSION_MAJOR }}-bin
docker push composer/composer:${{ env.COMPOSER_VERSION_MAJOR_MINOR }}
docker push composer/composer:${{ env.COMPOSER_VERSION_MAJOR_MINOR }}-bin
docker push composer/composer:${{ env.COMPOSER_VERSION_MAJOR_MINOR_PATCH }}
docker push composer/composer:${{ env.COMPOSER_VERSION_MAJOR_MINOR_PATCH }}-bin
- name: Login to Amazon Public ECR
if: github.ref == 'refs/heads/main'
uses: docker/login-action@v3
with:
registry: public.ecr.aws
username: ${{ secrets.AWS_ECR_ACCESS_KEY }}
password: ${{ secrets.AWS_ECR_SECRET_KEY }}
- name: Push tag(s) to Amazon Public ECR
if: github.ref == 'refs/heads/main'
run: |
docker tag composer/composer:${{ env.COMPOSER_VERSION_MAJOR }} ${{ env.ECR_REPO }}:${{ env.COMPOSER_VERSION_MAJOR }}
docker tag composer/composer:${{ env.COMPOSER_VERSION_MAJOR }}-bin ${{ env.ECR_REPO }}:${{ env.COMPOSER_VERSION_MAJOR }}-bin
docker tag composer/composer:${{ env.COMPOSER_VERSION_MAJOR_MINOR }} ${{ env.ECR_REPO }}:${{ env.COMPOSER_VERSION_MAJOR_MINOR }}
docker tag composer/composer:${{ env.COMPOSER_VERSION_MAJOR_MINOR }}-bin ${{ env.ECR_REPO }}:${{ env.COMPOSER_VERSION_MAJOR_MINOR }}-bin
docker tag composer/composer:${{ env.COMPOSER_VERSION_MAJOR_MINOR_PATCH }} ${{ env.ECR_REPO }}:${{ env.COMPOSER_VERSION_MAJOR_MINOR_PATCH }}
docker tag composer/composer:${{ env.COMPOSER_VERSION_MAJOR_MINOR_PATCH }}-bin ${{ env.ECR_REPO }}:${{ env.COMPOSER_VERSION_MAJOR_MINOR_PATCH }}-bin
docker push ${{ env.ECR_REPO }}:${{ env.COMPOSER_VERSION_MAJOR }}
docker push ${{ env.ECR_REPO }}:${{ env.COMPOSER_VERSION_MAJOR }}-bin
docker push ${{ env.ECR_REPO }}:${{ env.COMPOSER_VERSION_MAJOR_MINOR }}
docker push ${{ env.ECR_REPO }}:${{ env.COMPOSER_VERSION_MAJOR_MINOR }}-bin
docker push ${{ env.ECR_REPO }}:${{ env.COMPOSER_VERSION_MAJOR_MINOR_PATCH }}
docker push ${{ env.ECR_REPO }}:${{ env.COMPOSER_VERSION_MAJOR_MINOR_PATCH }}-bin