Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Integrate Notation by Notary Project to sign Ballerina Images #4661

Closed
Closed
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
47 changes: 43 additions & 4 deletions .github/workflows/publish-release-artifacts.yml
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,10 @@ on:
description: 'Release Version e.g., 2201.1.1, 2201.1.1-rc1'
default: '2201.1.1'
required: true
env:
REGISTRY: ghcr.io
ORGNAME: ballerina-platform
IMAGE_NAME: ballerina

jobs:
publish-artifacts:
Expand Down Expand Up @@ -133,13 +137,11 @@ jobs:
run: |
DOCKER_REPO=${{ steps.process-docker.outputs.dockerRepo }}
cp $VERSION/ballerina-$VERSION.zip $DOCKER_REPO/base/docker/

docker build --no-cache=true --squash --build-arg BALLERINA_DIST=ballerina-$VERSION.zip -t ballerina/ballerina:$GIT_TAG $DOCKER_REPO/base/docker/
rm $DOCKER_REPO/base/docker/ballerina-$VERSION.zip
docker push ballerina/ballerina:$GIT_TAG
docker rmi ballerina/ballerina:$GIT_TAG
docker image prune -f


- name: Build and push dev container
run: |
DOCKER_REPO=${{ steps.process-docker.outputs.dockerRepo }}
Expand All @@ -151,6 +153,42 @@ jobs:
docker rmi ballerina/ballerina-devcontainer:$GIT_TAG
docker image prune -f

- name: azure-resource-login
uses: Azure/azure-resource-login-action@v1.0.0
with:
creds: ${{ secrets.AZURE_CREDENTIALS }}

- name: Setup Notation with azure-kv plugin
uses: Duffney/setup-notation@v1.0.0
with:
version: 1.0.0-rc.7
key_name: ${{ secrets.AZURE_KEY_NAME }}
certificate_key_id: ${{ secrets.AZURE_KEY_ID }}
plugin_name: notation-azure-kv
plugin_version: 0.5.0-rc.1

- name: Login to GitHub Container Registry
uses: docker/login-action@v2
with:
registry: ${{ env.REGISTRY }}
username: ${{ env.ORGNAME }}
password: ${{ secrets.BALLERINA_BOT_TOKEN }}

- name: Push image to Github Container Registry
run: |
docker tag ballerina/ballerina:$GIT_TAG ${{ env.REGISTRY }}/${{ env.ORGNAME }}/${{ env.IMAGE_NAME }}:$GIT_TAG
docker push ${{ env.REGISTRY }}/${{ env.ORGNAME }}/${{ env.IMAGE_NAME }}:$GIT_TAG

- name: Verify key generation
run: notation key list

- name: Sign the published Docker image
run: |
notation sign --key ${{ secrets.AZURE_KEY_NAME }} ${{ env.REGISTRY }}/${{ env.ORGNAME }}/${{ env.IMAGE_NAME }}:$GIT_TAG
docker rmi ballerina/ballerina:$GIT_TAG
docker rmi ${{ env.REGISTRY }}/${{ env.ORGNAME }}/${{ env.IMAGE_NAME }}:$GIT_TAG
docker image prune -f

- name: Publish Artifacts
run: |
sudo apt-get install python3-setuptools
Expand All @@ -161,3 +199,4 @@ jobs:
env:
s3_acc_id: ${{ secrets.S3_ID }}
s3_acc_key: ${{ secrets.S3_KEY }}