Skip to content
Merged
Show file tree
Hide file tree
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
72 changes: 72 additions & 0 deletions .github/workflows/docker-image.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,72 @@
name: Docker Image CI

on:
push:
branches: [ "daniel-koala", "adam", "bisha" ]
pull_request:
branches: [ "daniel-koala", "adam", "bisha" ]

env:
REGISTRY: ghcr.io

jobs:
build:
runs-on: ubuntu-latest

permissions:
contents: read
packages: write

steps:
- uses: actions/checkout@v5

- name: Set image name from branch
id: image-name
run: |
declare -A BRANCH_MAP
BRANCH_MAP[daniel-koala]="code-tracking-qa"
BRANCH_MAP[adam]="code-tracking-emote"
BRANCH_MAP[bisha]="code-tracking-ai"

BRANCH="${GITHUB_HEAD_REF:-$GITHUB_REF_NAME}"
IMAGE_NAME="${BRANCH_MAP[$BRANCH]}"

if [ -z "$IMAGE_NAME" ]; then
echo "No image mapping for branch: $BRANCH"
exit 1
fi

REPO_OWNER="${{ github.repository_owner }}"
echo "image_name=${REPO_OWNER,,}/${IMAGE_NAME}" >> "$GITHUB_OUTPUT"

- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3

- name: Log in to GitHub Container Registry
uses: docker/login-action@v3
with:
registry: ${{ env.REGISTRY }}
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}

- name: Extract metadata for Docker
id: meta
uses: docker/metadata-action@v5
with:
images: ${{ env.REGISTRY }}/${{ steps.image-name.outputs.image_name }}
tags: |
type=sha
type=ref,event=branch
type=ref,event=pr
type=raw,value=latest

- name: Build and push Docker image
uses: docker/build-push-action@v6
with:
context: .
file: ./Dockerfile
push: ${{ github.event_name != 'pull_request' }}
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
cache-from: type=gha
cache-to: type=gha,mode=max
3 changes: 1 addition & 2 deletions Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,7 @@ RUN gradle ij-server:buildFatJar --no-daemon
# Stage 3: Create the Runtime Image
FROM amazoncorretto:11 AS runtime
EXPOSE 8080
RUN mkdir /app \
# Make sure /data/tt-files directory exists in the runtime image
RUN mkdir /app
RUN mkdir -p /data/tt-files && chmod -R 777 /data/tt-files
COPY --from=build /home/gradle/src/ij-server/build/libs/ij-server-all.jar /app/ktor-docker-sample.jar
ENTRYPOINT ["java","-jar","/app/ktor-docker-sample.jar"]
Loading