Gem Caching Fix (#895) #509
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Build, Scan, and Lint Images | |
# If scanning fails, you can delete the cache and have it rebuild from scratch. | |
# This _may_ fix the vulnerability. Delete the caches prefixed with Linux-buildx-cas, | |
# specifically, if you look in the failed action at the Cache Docker Layers step, the | |
# layer listed under `Cache restored from key:` | |
# https://github.com/greenriver/boston-cas/actions/caches?query=linux-buildx | |
on: | |
push: | |
branches: | |
- "*" | |
- "**/*" | |
# Branch pushes will cancel any running jobs to the same branch | |
concurrency: | |
group: ${{ github.ref }}-newbuild | |
cancel-in-progress: true | |
jobs: | |
build: | |
name: Build | |
runs-on: ubuntu-22.04 | |
# Supports OIDC to fetch/push images from/to ECR | |
permissions: | |
contents: read | |
id-token: write | |
pull-requests: write | |
strategy: | |
fail-fast: false | |
matrix: | |
include: | |
- name: Open Path CAS | |
context: . | |
dockerfile: docker/app/Dockerfile | |
keep_latest_tag: true | |
cache_key: cas | |
hadolint_ignore: DL3018,DL3013 | |
trivy_skip_files: /app/config/key.pem,/app/docker/sftp/ssh_host_ed25519_key,/app/docker/sftp/ssh_host_rsa_key | |
target: prod-build | |
build-args: | | |
BUILD_TAG=3.1.6-alpine3.20 | |
BUNDLER_VERSION=2.5.17 | |
USER_ID=10000 | |
GROUP_ID=10000 | |
tags: | | |
type=sha,prefix=githash- | |
type=ref,event=branch,prefix=branch- | |
type=raw,event=branch,value=branch-{{branch}}-{{sha}} | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: Dockerfile Lint | |
shell: bash | |
run: | | |
docker run -v $(pwd)/.hadolint.yaml:/.hadolint.yaml \ | |
-e HADOLINT_IGNORE=${{ matrix.hadolint_ignore }} \ | |
-v $(pwd)/${{ matrix.dockerfile }}:/Dockerfile \ | |
--rm -i ghcr.io/hadolint/hadolint:latest-alpine hadolint /Dockerfile | |
- name: Set up Docker Buildx | |
id: buildx | |
uses: docker/setup-buildx-action@v3 | |
- name: Cache Docker layers | |
uses: actions/cache@v4 | |
with: | |
path: /tmp/.buildx-cache | |
key: ${{ runner.os }}-buildx-${{ matrix.cache_key }}-${{ github.run_id }} | |
restore-keys: | | |
${{ runner.os }}-buildx-${{ matrix.cache_key }} | |
- name: Configure AWS credentials for OIDC | |
uses: aws-actions/configure-aws-credentials@v4 | |
with: | |
aws-region: us-east-1 | |
role-to-assume: arn:aws:iam::${{ secrets.AWS_ACCOUNT_ID }}:role/${{ secrets.AWS_ROLE_NAME }} | |
role-session-name: warehouse-github-action | |
- name: Prepare | |
id: prep | |
env: | |
SHA: ${{ github.sha }} | |
BRANCH: ${{ github.ref_name }} | |
run: | | |
echo $SHA > docker/app/REVISION | |
echo $BRANCH > docker/app/GIT_BRANCH | |
bin/error_if_githash_is_latest.rb base | |
# https://github.com/docker/metadata-action#images-input | |
- name: Docker metadata | |
id: meta | |
uses: docker/metadata-action@v5 | |
env: | |
DOCKER_METADATA_SHORT_SHA_LENGTH: 7 | |
with: | |
images: ${{ secrets.ECR_REPOSITORY_URI }} | |
flavor: ${{ matrix.flavor }} | |
tags: ${{ matrix.tags }} | |
- name: Log in to ECR | |
shell: bash | |
env: | |
image: ${{ secrets.ECR_REPOSITORY_URI }} | |
run: | | |
username=AWS | |
export AWS_REGION=us-east-1 | |
echo Getting password for ECR | |
password=$(aws ecr get-login-password --region us-east-1) | |
host=$(echo $image | cut -d/ -f1) | |
echo Logging in to $host | |
echo $password | docker login $host -u $username --password-stdin | |
# https://github.com/docker/build-push-action | |
- name: Build image | |
uses: docker/build-push-action@v5 | |
with: | |
context: ${{ matrix.context }} | |
builder: ${{ steps.buildx.outputs.name }} | |
labels: ${{ steps.meta.outputs.labels }} | |
target: ${{ matrix.target }} | |
file: ${{ matrix.dockerfile }} | |
load: true | |
tags: ${{ secrets.ECR_REPOSITORY_URI }} | |
build-args: ${{ matrix.build-args }} | |
cache-from: type=local,src=/tmp/.buildx-cache/${{ matrix.cache_key }} | |
cache-to: type=local,dest=/tmp/.buildx-cache/${{ matrix.cache_key }},mode=max | |
- name: Push image with tags | |
env: | |
image: ${{ secrets.ECR_REPOSITORY_URI }} | |
run: | | |
echo "${{ steps.meta.outputs.tags }}" | xargs -I TAG -n1 docker tag ${image} TAG | |
# docker image ls | |
if [[ "${{ matrix.keep_latest_tag }}" != "true" ]] | |
then | |
docker image rm ${image}:latest | |
fi | |
docker push --all-tags ${image} | |
- name: Check trivy db sha | |
id: trivy-db | |
env: | |
GH_TOKEN: ${{ github.token }} | |
run: | | |
endpoint='/orgs/aquasecurity/packages/container/trivy-db/versions' | |
headers='Accept: application/vnd.github+json' | |
jqFilter='.[] | select(.metadata.container.tags[] | contains("latest")) | .name | sub("sha256:";"")' | |
sha=$(gh api -H "${headers}" "${endpoint}" | jq --raw-output "${jqFilter}") | |
echo "Trivy DB sha256:${sha}" | |
echo "sha=${sha}" >> $GITHUB_OUTPUT | |
- name: Cache trivy db | |
uses: actions/cache@v4 | |
with: | |
path: .trivy | |
key: ${{ runner.os }}-trivy-db-${{ steps.trivy-db.outputs.sha }} | |
# https://github.com/aquasecurity/trivy-action | |
- name: Run vulnerability scan | |
id: vuln_scan | |
uses: aquasecurity/[email protected] | |
env: | |
TRIVY_DB_REPOSITORY: "public.ecr.aws/aquasecurity/trivy-db:2" | |
TRIVY_JAVA_DB_REPOSITORY: "public.ecr.aws/aquasecurity/trivy-java-db:1" | |
with: | |
image-ref: ${{ secrets.ECR_REPOSITORY_URI }} | |
format: 'table' | |
exit-code: '1' | |
ignore-unfixed: true | |
severity: 'CRITICAL,HIGH' | |
cache-dir: .trivy | |
skip-files: ${{ matrix.trivy_skip_files }} | |
- name: Fix .trivy permissions | |
run: sudo chown -R $(stat . -c %u:%g) .trivy | |
# Not completely sure this remains private | |
# - name: Report | |
# shell: bash | |
# run: | | |
# echo "### Tags" >> $GITHUB_STEP_SUMMARY | |
# echo "${{ steps.meta.outputs.tags }}" >> $GITHUB_STEP_SUMMARY | |
# echo '' >> $GITHUB_STEP_SUMMARY |