diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 565fbe2..0e4171b 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -1,19 +1,13 @@ name: Create and publish AEM images -on: - push: - branches: ["main"] - workflow_dispatch: +on: [ push ] env: - REGISTRY: ghcr.io - IMAGE_NAME: ${{ github.repository }} - AEM_SDK_VERSION: 2024.10.18459.20241031T210302Z-241000 + registry: ghcr.io + aem_sdk_version: 2024.10.18459.20241031T210302Z-241000 jobs: - build-and-push-image: - name: Build and push AEM image - runs-on: ubuntu-latest + build-images: permissions: contents: read packages: write @@ -21,7 +15,9 @@ jobs: id-token: write strategy: matrix: - runmode: ["author", "publish"] + arch: [ arm64, amd64 ] + runmode: [ author, publish ] + runs-on: ubuntu-latest steps: - name: Checkout repository uses: actions/checkout@v4 @@ -29,7 +25,7 @@ jobs: uses: actions/cache@v4 with: path: aem-sdk-artifacts - key: aem-sdk-${{ env.AEM_SDK_VERSION }}.zip + key: aem-sdk-${{ env.aem_sdk_version }}.zip - name: Checkout AEM SDK artifacts repository uses: actions/checkout@v4 with: @@ -41,33 +37,37 @@ jobs: uses: docker/setup-qemu-action@v3 - name: Set up Docker Buildx uses: docker/setup-buildx-action@v3 + with: + platforms: linux/${{ matrix.arch }} - name: Log in to the Container registry + if: github.ref == 'refs/heads/main' uses: docker/login-action@v3 with: - registry: ${{ env.REGISTRY }} + registry: ${{ env.registry }} username: ${{ github.actor }} password: ${{ secrets.GITHUB_TOKEN }} - name: Extract metadata id: meta uses: docker/metadata-action@v3 with: - images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }} + images: ${{ env.registry }}/${{ github.repository }} - name: Build and push docker image id: push uses: docker/build-push-action@v3 with: context: . - push: true - tags: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME}}:${{ matrix.runmode }}-${{ env.AEM_SDK_VERSION }} - platforms: linux/amd64,linux/arm64 + push: ${{ github.ref == 'refs/heads/main' }} + tags: ${{ env.registry }}/${{ github.repository }}:${{ matrix.runmode }}-${{ env.aem_sdk_version }}-${{ matrix.arch }} + platforms: linux/${{ matrix.arch }} labels: ${{ steps.meta.outputs.labels }} build-args: | RUNMODE=${{ matrix.runmode }} PORT=${{ matrix.runmode == 'author' && '4502' || '4503' }} - name: Generate artifact attestation + if: github.ref == 'refs/heads/develop' uses: actions/attest-build-provenance@v1 with: - subject-name: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME}} + subject-name: ${{ env.registry }}/${{ github.repository }} subject-digest: ${{ steps.push.outputs.digest }} push-to-registry: true diff --git a/Dockerfile b/Dockerfile index a138425..90b7ecb 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,6 +1,5 @@ FROM azul/zulu-openjdk:11-jre-headless -ARG TARGETOS ARG TARGETARCH ARG AEMC_VERSION=2.0.3 @@ -19,7 +18,7 @@ RUN apt-get update &&\ apt-get install -y --no-install-recommends curl &&\ apt-get clean &&\ rm -rf /var/cache/apk/* &&\ - curl -L https://github.com/wttech/aemc/releases/download/v${AEMC_VERSION}/aemc-cli_${TARGETOS}_${TARGETARCH}.tar.gz | tar -xz -C /usr/local/bin + curl -L https://github.com/wttech/aemc/releases/download/v${AEMC_VERSION}/aemc-cli_linux_${TARGETARCH}.tar.gz | tar -xz -C /usr/local/bin COPY aem-sdk-artifacts/aem-sdk-*.zip aem/home/lib/ COPY aem/default/etc/aem.yml aem/default/etc/aem.yml