mirror of
https://github.com/koreanbots/core.git
synced 2025-12-16 06:20:24 +00:00
chore: push docker image to ghcr (#603)
This commit is contained in:
parent
eaf9ef2360
commit
04255b52d9
67
.github/workflows/publish-stable.yml
vendored
67
.github/workflows/publish-stable.yml
vendored
@ -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 }}
|
||||||
63
.github/workflows/publish.yml
vendored
63
.github/workflows/publish.yml
vendored
@ -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 }}
|
||||||
Loading…
x
Reference in New Issue
Block a user