chore: push docker image to ghcr (#603)

This commit is contained in:
SKINMAKER 2023-06-30 12:01:37 +09:00 committed by GitHub
parent eaf9ef2360
commit 04255b52d9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 81 additions and 49 deletions

View File

@ -1,40 +1,57 @@
name: Publish name: Publish Stable
on: on:
release: workflow_dispatch:
types: [published]
env:
REGISTRY: ghcr.io
NAME: koreanbots/core
jobs: jobs:
image-push: image-push:
name: Push stable docker image name: Push docker image
runs-on: ubuntu-latest runs-on: ubuntu-latest
permissions:
contents: read
packages: write
steps: steps:
- uses: actions/checkout@v2 - uses: actions/checkout@v2
with: with:
submodules: true submodules: true
- uses: docker/setup-buildx-action@v1
- name: Parse image tag - name: Parse image tag
run: | run: |
parsed=${GITHUB_REF#refs/*/} parsed=${GITHUB_REF#refs/*/}
echo "RELEASE_TAG=${parsed//\//-}" >> $GITHUB_ENV echo "RELEASE_TAG=${parsed//\//-}" >> $GITHUB_ENV
- name: Configure AWS credentials - name: Set up Docker Buildx
uses: aws-actions/configure-aws-credentials@v1 uses: docker/setup-buildx-action@v2
- name: Log in to the Container registry
uses: docker/login-action@v2
with: with:
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} registry: ${{ env.REGISTRY }}
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} username: ${{ github.actor }}
aws-region: ap-northeast-2 password: ${{ secrets.GITHUB_TOKEN }}
- name: Login to Amazon ECR - name: Get metadata for Docker
id: login-ecr uses: docker/metadata-action@v4
uses: aws-actions/amazon-ecr-login@v1 id: meta
with:
images: ${{ env.REGISTRY }}/${{ env.NAME }}
tags: |
type=raw,value=latest,priority=100
type=raw,value=stable,priority=200
type=sha,prefix=,suffix=,format=short,priority=300
type=schedule,pattern={{date 'YYYYMMDD-hhmmss' tz='Asia/Seoul'}}
- name: Build and push - name: Build and push
env: uses: docker/build-push-action@v4
SENTRY_AUTH_TOKEN: ${{ secrets.SENTRY_AUTH_TOKEN }} with:
NEXT_PUBLIC_SENTRY_DSN: ${{ secrets.SENTRY_DSN }} context: .
SENTRY_DSN: ${{ secrets.SENTRY_DSN }} push: true
ECR_REGISTRY: ${{ steps.login-ecr.outputs.registry }} tags: ${{ steps.meta.outputs.tags }}
IMAGE_TAG: ${{ github.sha }} labels: ${{ steps.meta.outputs.labels }}
NEXT_PUBLIC_HCAPTCHA_SITEKEY: ${{ secrets.NEXT_PUBLIC_HCAPTCHA_SITEKEY }} cache-from: type=gha
run: | cache-to: type=gha,mode=max
printf 'defaults.url=https://sentry.io/\ndefaults.org=koreanbots\ndefaults.project=client' > sentry.properties build-args: |
docker build --build-arg NEXT_PUBLIC_HCAPTCHA_SITEKEY=$NEXT_PUBLIC_HCAPTCHA_SITEKEY --build-arg SENTRY_AUTH_TOKEN=$SENTRY_AUTH_TOKEN --build-arg NEXT_PUBLIC_SENTRY_DSN=$NEXT_PUBLIC_SENTRY_DSN --build-arg SENTRY_DSN=$SENTRY_DSN --build-arg SOURCE_COMMIT=${{ env.GITHUB_SHA }} --build-arg TAG=${{ env.RELEASE_TAG }} -t koreanlist . SENTRY_AUTH_TOKEN=${{ secrets.SENTRY_AUTH_TOKEN }}
docker tag koreanlist:latest ${{ secrets.AWS_IMAGE_URL }}:stable NEXT_PUBLIC_SENTRY_DSN=${{ secrets.SENTRY_DSN }}
docker push ${{ secrets.AWS_IMAGE_URL }} --all-tags SENTRY_DSN=${{ secrets.SENTRY_DSN }}
NEXT_PUBLIC_HCAPTCHA_SITEKEY=${{ secrets.NEXT_PUBLIC_HCAPTCHA_SITEKEY }}
SOURCE_COMMIT=${{ github.sha }}
TAG=${{ env.RELEASE_TAG }}

View File

@ -1,41 +1,56 @@
name: Publish name: Publish
on: on:
push: workflow_dispatch:
branches: [master]
env:
REGISTRY: ghcr.io
NAME: koreanbots/core
jobs: jobs:
image-push: image-push:
name: Push docker image name: Push docker image
runs-on: ubuntu-latest runs-on: ubuntu-latest
permissions:
contents: read
packages: write
steps: steps:
- uses: actions/checkout@v2 - uses: actions/checkout@v2
with: with:
submodules: true submodules: true
- uses: docker/setup-buildx-action@v1
- name: Parse image tag - name: Parse image tag
run: | run: |
parsed=${GITHUB_REF#refs/*/} parsed=${GITHUB_REF#refs/*/}
echo "RELEASE_TAG=${parsed//\//-}" >> $GITHUB_ENV echo "RELEASE_TAG=${parsed//\//-}" >> $GITHUB_ENV
- name: Configure AWS credentials - name: Set up Docker Buildx
uses: aws-actions/configure-aws-credentials@v1 uses: docker/setup-buildx-action@v2
- name: Log in to the Container registry
uses: docker/login-action@v2
with: with:
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} registry: ${{ env.REGISTRY }}
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} username: ${{ github.actor }}
aws-region: ap-northeast-2 password: ${{ secrets.GITHUB_TOKEN }}
- name: Login to Amazon ECR - name: Get metadata for Docker
id: login-ecr uses: docker/metadata-action@v4
uses: aws-actions/amazon-ecr-login@v1 id: meta
with:
images: ${{ env.REGISTRY }}/${{ env.NAME }}
tags: |
type=raw,value=latest,priority=100
type=sha,prefix=,suffix=,format=short,priority=300
type=schedule,pattern={{date 'YYYYMMDD-hhmmss' tz='Asia/Seoul'}}
- name: Build and push - name: Build and push
env: uses: docker/build-push-action@v4
SENTRY_AUTH_TOKEN: ${{ secrets.SENTRY_AUTH_TOKEN }} with:
NEXT_PUBLIC_SENTRY_DSN: ${{ secrets.SENTRY_DSN }} context: .
SENTRY_DSN: ${{ secrets.SENTRY_DSN }} push: true
ECR_REGISTRY: ${{ steps.login-ecr.outputs.registry }} tags: ${{ steps.meta.outputs.tags }}
IMAGE_TAG: ${{ github.sha }} labels: ${{ steps.meta.outputs.labels }}
NEXT_PUBLIC_HCAPTCHA_SITEKEY: ${{ secrets.NEXT_PUBLIC_HCAPTCHA_SITEKEY }} cache-from: type=gha
run: | cache-to: type=gha,mode=max
printf 'defaults.url=https://sentry.io/\ndefaults.org=koreanbots\ndefaults.project=client' > sentry.properties build-args: |
docker build --build-arg NEXT_PUBLIC_HCAPTCHA_SITEKEY=$NEXT_PUBLIC_HCAPTCHA_SITEKEY --build-arg SENTRY_AUTH_TOKEN=$SENTRY_AUTH_TOKEN --build-arg NEXT_PUBLIC_SENTRY_DSN=$NEXT_PUBLIC_SENTRY_DSN --build-arg SENTRY_DSN=$SENTRY_DSN --build-arg SOURCE_COMMIT=${{ env.GITHUB_SHA }} --build-arg TAG=${{ env.RELEASE_TAG }} -t koreanlist . SENTRY_AUTH_TOKEN=${{ secrets.SENTRY_AUTH_TOKEN }}
docker tag koreanlist:latest ${{ secrets.AWS_IMAGE_URL }}:latest NEXT_PUBLIC_SENTRY_DSN=${{ secrets.SENTRY_DSN }}
docker tag koreanlist:latest ${{ secrets.AWS_IMAGE_URL }}:${{ env.RELEASE_TAG == 'master' && 'nightly' || env.RELEASE_TAG }} SENTRY_DSN=${{ secrets.SENTRY_DSN }}
docker push ${{ secrets.AWS_IMAGE_URL }} --all-tags NEXT_PUBLIC_HCAPTCHA_SITEKEY=${{ secrets.NEXT_PUBLIC_HCAPTCHA_SITEKEY }}
SOURCE_COMMIT=${{ github.sha }}
TAG=${{ env.RELEASE_TAG }}