Skip to content

Commit

Permalink
CI to publish docker images (#10)
Browse files Browse the repository at this point in the history
* - init

* code review change

* - added tag files

* - updated tag to 1.1.4

* - fixed file extension

* - changed secret

* - test run

* bash fix

* - turn off test run
  • Loading branch information
nshyrei authored Apr 25, 2024
1 parent 916d16c commit 5e4a31c
Show file tree
Hide file tree
Showing 3 changed files with 83 additions and 0 deletions.
81 changes: 81 additions & 0 deletions .github/workflows/build-docker-images.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,81 @@
name: Build and publish Docker Images

on:
push:
branches: [ "master" ]
paths:
- 'docker/enclave-base/**'
- 'docker/parent-base/**'
pull_request:
branches: [ "master" ]
types:
- closed
- opened
paths:
- 'docker/enclave-base/**'
- 'docker/parent-base/**'

jobs:
build-docker-images:
runs-on: ubuntu-20.04
if: github.event_name == 'pull_request' && (github.event.action == 'opened' || github.event.action == 'edited')
steps:
- name: Pull main repository
uses: actions/checkout@v3
with:
repository: fortanix/salmiac

- name: Build docker images
run: |
cd docker/enclave-base
TAG=$(cat tag)
docker build -t fortanix/enclave-base:$TAG .
docker save -o /tmp/enclave-base.tar fortanix/enclave-base
cd ../parent-base
TAG=$(cat tag)
docker build -t fortanix/parent-base:$TAG .
docker save -o /tmp/parent-base.tar fortanix/parent-base
- name: Upload enclave-base artifact
uses: actions/upload-artifact@v3
with:
name: enclave-base
path: /tmp/enclave-base.tar

- name: Upload parent-base artifact
uses: actions/upload-artifact@v3
with:
name: parent-base
path: /tmp/parent-base.tar

push-docker-images:
runs-on: ubuntu-20.04
needs: build-docker-images
if: github.event_name == 'pull_request' && github.event.action == 'closed' && github.event.pull_request.merged == true
steps:
- name: Download enclave-base artifact
uses: actions/download-artifact@v3
with:
name: enclave-base
path: /tmp/enclave-base

- name: Download parent-base artifact
uses: actions/download-artifact@v3
with:
name: parent-base
path: /tmp/parent-base

- name: Login to Docker Hub
uses: docker/login-action@v1
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PAT }}

- name: Load and push docker images
run: |
enclave_base_load_output=$(docker load --input /tmp/enclave-base/enclave-base.tar)
parent_base_load_output=$(docker load --input /tmp/parent-base/parent-base.tar)
docker push $(echo $enclave_base_load_output | awk '{print $3}')
docker push $(echo $parent_base_load_output | awk '{print $3}')
1 change: 1 addition & 0 deletions docker/enclave-base/tag
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
1.0.2
1 change: 1 addition & 0 deletions docker/parent-base/tag
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
1.1.4

0 comments on commit 5e4a31c

Please sign in to comment.