Skip to content

Commit

Permalink
adding basic docker container
Browse files Browse the repository at this point in the history
  • Loading branch information
gilesw committed Nov 29, 2024
1 parent 8187c3b commit 435ca8e
Show file tree
Hide file tree
Showing 33 changed files with 4,593 additions and 0 deletions.
159 changes: 159 additions & 0 deletions .github/workflows/bld_docker.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,159 @@
name: bld_docker

permissions:
checks: write
contents: read
issues: read
pull-requests: write

on:
workflow_call:
inputs:
docker_name:
description: 'Name of the docker image to build'
required: false
default: "orcid/version-bumping-test"
type: string
context:
description: 'Name of the context in the repo'
required: false
default: "."
type: string
build_args:
description: 'build_args e.g wibble=blar'
required: false
default: ""
type: string
file:
description: 'specify a custom dockerfile'
required: false
default: ""
type: string
version_tag:
description: 'Name of the tag to build'
required: false
default: 'latest'
type: string
bump:
description: 'whether to bump the version number by a major minor patch amount or none'
required: false
default: 'patch'
type: string
ref:
description: 'git reference to use with the checkout use default_branch to have that calculated'
required: false
default: "default"
type: string
push:
description: 'Select to push to docker registry'
required: false
default: true
type: boolean

workflow_dispatch:
inputs:
docker_name:
description: 'Name of the docker image to build'
required: false
default: "orcid/version-bumping-test"
type: string
context:
description: 'Name of the context in the repo'
required: false
default: "."
type: string
build_args:
description: 'build_args e.g wibble=blar'
required: false
default: ""
type: string
file:
description: 'specify a custom dockerfile'
required: false
default: ""
type: string
version_tag:
description: 'Name of the tag to build'
required: false
default: 'latest'
type: string
bump:
description: 'whether to bump the version number by a major minor patch amount or none'
required: false
default: 'patch'
type: string
ref:
description: 'git reference to use with the checkout use default_branch to have that calculated'
required: false
default: "default"
type: string
push:
description: 'Select to push to docker registry'
required: false
default: true
type: boolean

jobs:
bld_docker:
strategy:
matrix:
include:
- artifact_name: orcid-web
docker_name: orcid/registry/orcid-web
file: orcid-web/Dockerfile

- artifact_name: orcid-web-proxy
docker_name: orcid/registry/orcid-web-proxy
file: orcid-web-proxy/Dockerfile

runs-on: ubuntu-latest
steps:
- name: git-checkout-ref-action
id: ref
uses: ORCID/git-checkout-ref-action@main
with:
default_branch: ${{ github.event.repository.default_branch }}
ref: ${{ inputs.ref }}

- uses: actions/checkout@v4
with:
ref: ${{ steps.ref.outputs.ref }}
# checkout some history so we can scan commits for bump messages
# NOTE: history does not include tags!
fetch-depth: 100

- name: find next version
id: version
uses: ORCID/version-bump-action@main
with:
version_tag: ${{ inputs.version_tag }}
bump: ${{ inputs.bump }}

- uses: docker/setup-buildx-action@v3

- name: Login to private registry
uses: docker/login-action@v3
with:
registry: ${{ secrets.DOCKER_REG_PRIVATE }}
username: ${{ secrets.DOCKER_USER }}
password: ${{ secrets.DOCKER_PASSWORD }}

- name: nasty hack to allow dynamic defaults
id: dynamic_defaults
run: |
FILE="${{ matrix.file }}"
echo "default_file=${FILE:-${{ inputs.context }}/Dockerfile}" >> "$GITHUB_OUTPUT"
- name: show the dynamic defaults
run: |
echo ${{ steps.dynamic_defaults.outputs.default_file }}
- uses: docker/build-push-action@v6
with:
push: ${{ inputs.push }}
tags: ${{ secrets.DOCKER_REG_PRIVATE }}/${{ matrix.docker_name}}:${{ steps.version.outputs.version_tag_numeric }}
context: ${{ inputs.context }}
cache-from: type=registry,ref=${{ secrets.DOCKER_REG_PRIVATE }}/${{ matrix.docker_name }}:cache
cache-to: type=registry,mode=max,image-manifest=true,oci-mediatypes=true,ref=${{ secrets.DOCKER_REG_PRIVATE }}/${{ matrix.docker_name }}:cache
file: ${{ steps.dynamic_defaults.outputs.default_file }}

100 changes: 100 additions & 0 deletions Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,100 @@
# dependencies docker build

# match version from .tool-versions
FROM maven:3.6.3-jdk-11 AS maven

ARG tag_numeric

WORKDIR /build

# copy only poms for max cachability of just dependency downloads
COPY pom.xml .
COPY orcid-core/pom.xml orcid-core/pom.xml
COPY orcid-persistence/pom.xml orcid-persistence/pom.xml
COPY orcid-utils/pom.xml orcid-utils/pom.xml
COPY orcid-test/pom.xml orcid-test/pom.xml
COPY orcid-api-common/pom.xml orcid-api-common/pom.xml
COPY orcid-scheduler-web/pom.xml orcid-scheduler-web/pom.xml
COPY orcid-api-web/pom.xml orcid-api-web/pom.xml
COPY orcid-message-listener/pom.xml orcid-message-listener/pom.xml
COPY orcid-core/pom.xml orcid-core/pom.xml
COPY orcid-web/pom.xml orcid-web/pom.xml
COPY orcid-internal-api/pom.xml orcid-internal-api/pom.xml
COPY orcid-pub-web/pom.xml orcid-pub-web/pom.xml
COPY orcid-activemq/pom.xml orcid-activemq/pom.xml

# FIXME: these dont seem required?
#COPY orcid-web-frontend/pom.xml orcid-web-frontend/pom.xml
#COPY orcid-activities-indexer/pom.xml orcid-activities-indexer/pom.xml
#COPY orcid-nodejs/pom.xml orcid-nodejs/pom.xml

# download maven dependencies and ignore that some components will fail
RUN mvn -T 1C --batch-mode dependency:resolve --fail-never -Dorg.slf4j.simpleLogger.log.org.apache.maven.cli.transfer.Slf4jMavenTransferListener=warn

# install orcid-parent into our local maven repo because the builds depend a version tagged release
RUN mvn -T 1C --batch-mode --non-recursive clean install -DskipTests \
-Dorg.slf4j.simpleLogger.log.org.apache.maven.cli.transfer.Slf4jMavenTransferListener=warn

# install orcid-utils into our local maven repo because the builds depend a version tagged release
COPY orcid-utils/src orcid-utils/src
RUN mvn -T 1C --batch-mode --projects orcid-utils clean install -DskipTests \
-Dorg.slf4j.simpleLogger.log.org.apache.maven.cli.transfer.Slf4jMavenTransferListener=warn

# install orcid-test into our local maven repo because orcid-persistence depends on it
COPY orcid-test/src orcid-test/src
RUN mvn -T 1C --batch-mode --projects orcid-test clean install -DskipTests \
-Dorg.slf4j.simpleLogger.log.org.apache.maven.cli.transfer.Slf4jMavenTransferListener=warn

# install orcid-persistence into our local maven repo because orcid-core depends on it
COPY orcid-persistence/src orcid-persistence/src
RUN mvn -T 1C --batch-mode --projects orcid-persistence clean install -DskipTests \
-Dorg.slf4j.simpleLogger.log.org.apache.maven.cli.transfer.Slf4jMavenTransferListener=warn

# install orcid-core into our local maven repo because the builds depend a version tagged release
COPY orcid-core/src orcid-core/src
RUN mvn -T 1C --batch-mode --projects orcid-core clean install -DskipTests \
-Dorg.slf4j.simpleLogger.log.org.apache.maven.cli.transfer.Slf4jMavenTransferListener=warn

# install orcid-api-common into our local maven repo because orcid-web deploy depends a version tagged release
COPY orcid-api-common/src orcid-api-common/src
RUN mvn -T 1C --batch-mode --projects orcid-api-common clean install -DskipTests \
-Dorg.slf4j.simpleLogger.log.org.apache.maven.cli.transfer.Slf4jMavenTransferListener=warn

##################################################################################
COPY orcid-web/src orcid-web/src
RUN mvn -T 1C --batch-mode -DgenerateBackupPoms=false \
--projects orcid-web -am package -DskipTests \
-Dorg.slf4j.simpleLogger.log.org.apache.maven.cli.transfer.Slf4jMavenTransferListener=warn

# For Java 11 and Tomcat 9
FROM tomcat:9.0.93-jdk11-temurin-jammy

# Focal has no j2cli support
# FROM tomcat:9.0.91-jdk11-temurin-focal

# copy jar file from build
COPY --from=maven /build/*/target/*.war /usr/local/tomcat/webapps/orcid-web.war

RUN mkdir -p /usr/local/tomcat/newrelic
COPY newrelic.yml /usr/local/tomcat/newrelic/newrelic.yml
RUN curl -L -s https://download.newrelic.com/newrelic/java-agent/newrelic-agent/8.13.0/newrelic-agent-8.13.0.jar -o /usr/local/tomcat/newrelic/newrelic.jar

RUN apt-get update
RUN apt-get install -y j2cli

# add orcid ca to allow Java application to trust other containers
ADD certs/cacerts /opt/java/openjdk/lib/security/cacerts

# add orcid ca to system to allow curl healthchecks to work
ADD certs/ca-certificates.crt /etc/ssl/certs/ca-certificates.crt


COPY entrypoint.sh .
RUN chmod +x ./entrypoint.sh

COPY orcid-web/*.j2 .

COPY orcid-web/log4j2.xml .

ENTRYPOINT ./entrypoint.sh

Empty file added certs/DONE.state
Empty file.
Loading

0 comments on commit 435ca8e

Please sign in to comment.