mirror of
https://github.com/tcgdex/cards-database.git
synced 2025-06-15 00:49:18 +00:00
feat: Add support for ARM servers (#528)
This commit is contained in:
@ -19,4 +19,3 @@ dist/
|
|||||||
|
|
||||||
# production
|
# production
|
||||||
/server/dist
|
/server/dist
|
||||||
/server/generated
|
|
||||||
|
122
.github/workflows/build.yml
vendored
122
.github/workflows/build.yml
vendored
@ -1,63 +1,85 @@
|
|||||||
name: Build Docker image
|
name: Build Docker image
|
||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches:
|
|
||||||
- '*'
|
env:
|
||||||
tags:
|
REGISTRY_IMAGE: |
|
||||||
- v*
|
ghcr.io/tcgdex/server
|
||||||
pull_request:
|
tcgdex/server
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
build:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
name: Build TCGdex Server
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
with:
|
|
||||||
fetch-depth: 0
|
|
||||||
|
|
||||||
- name: Docker meta
|
- name: Checkout
|
||||||
id: meta
|
uses: actions/checkout@v4
|
||||||
uses: docker/metadata-action@v5
|
with:
|
||||||
with:
|
# fetch full history for `updated` support
|
||||||
images: |
|
fetch-depth: 0
|
||||||
ghcr.io/tcgdex/server
|
|
||||||
tcgdex/server
|
|
||||||
tags: |
|
|
||||||
type=edge
|
|
||||||
type=ref,event=pr
|
|
||||||
type=ref,event=branch,prefix=branch-
|
|
||||||
type=semver,pattern={{version}}
|
|
||||||
type=semver,pattern={{major}}.{{minor}}
|
|
||||||
type=semver,pattern={{major}}
|
|
||||||
type=semver,pattern=latest
|
|
||||||
|
|
||||||
- name: Login to Docker Hub
|
- name: Docker meta
|
||||||
uses: docker/login-action@v3
|
id: meta
|
||||||
with:
|
uses: docker/metadata-action@v5
|
||||||
username: ${{ secrets.DOCKERHUB_USER }}
|
with:
|
||||||
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
images: ${{ env.REGISTRY_IMAGE }}
|
||||||
if: ${{ !github.event.pull_request.head.repo.fork && github.actor != 'dependabot[bot]' }}
|
tags: |
|
||||||
|
type=edge
|
||||||
|
type=ref,event=pr
|
||||||
|
type=ref,event=branch,prefix=branch-
|
||||||
|
type=semver,pattern={{version}}
|
||||||
|
type=semver,pattern={{major}}.{{minor}}
|
||||||
|
type=semver,pattern={{major}}
|
||||||
|
type=semver,pattern=latest
|
||||||
|
|
||||||
- name: Login to Github Packages
|
- name: Login to Docker Hub
|
||||||
uses: docker/login-action@v3
|
uses: docker/login-action@v3
|
||||||
with:
|
with:
|
||||||
registry: ghcr.io
|
username: ${{ secrets.DOCKERHUB_USER }}
|
||||||
username: ${{ github.actor }}
|
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
||||||
password: ${{ secrets.DOCKER_TOKEN }}
|
if: ${{ !github.event.pull_request.head.repo.fork && github.actor != 'dependabot[bot]' }}
|
||||||
if: ${{ !github.event.pull_request.head.repo.fork && github.actor != 'dependabot[bot]' }}
|
|
||||||
|
|
||||||
- name: Set up Docker Buildx
|
- name: Login to Github Packages
|
||||||
uses: docker/setup-buildx-action@v3
|
uses: docker/login-action@v3
|
||||||
|
with:
|
||||||
|
registry: ghcr.io
|
||||||
|
username: ${{ github.actor }}
|
||||||
|
password: ${{ secrets.DOCKER_TOKEN }}
|
||||||
|
if: ${{ !github.event.pull_request.head.repo.fork && github.actor != 'dependabot[bot]' }}
|
||||||
|
|
||||||
|
- name: Set up QEMU
|
||||||
|
uses: docker/setup-qemu-action@v3
|
||||||
|
|
||||||
|
- name: Set up Docker Buildx
|
||||||
|
uses: docker/setup-buildx-action@v3
|
||||||
|
|
||||||
|
- name: Setup Bun
|
||||||
|
uses: oven-sh/setup-bun@v2
|
||||||
|
with:
|
||||||
|
bun-version: latest
|
||||||
|
|
||||||
|
- name: Pre build server
|
||||||
|
run: |
|
||||||
|
bun install --frozen-lockfile
|
||||||
|
cd server
|
||||||
|
bun install --frozen-lockfile
|
||||||
|
bun run compile
|
||||||
|
rm -rf node_modules
|
||||||
|
cd ..
|
||||||
|
rm -rf node_modules
|
||||||
|
|
||||||
|
- name: Build and push
|
||||||
|
id: build
|
||||||
|
uses: docker/build-push-action@v6
|
||||||
|
with:
|
||||||
|
context: .
|
||||||
|
platforms: linux/amd64,linux/arm64
|
||||||
|
file: ./Dockerfile.github-actions
|
||||||
|
tags: ${{ steps.meta.outputs.tags }}
|
||||||
|
labels: ${{ steps.meta.outputs.labels }}
|
||||||
|
cache-from: type=gha
|
||||||
|
push: ${{ !github.event.pull_request.head.repo.fork && github.actor != 'dependabot[bot]' }}
|
||||||
|
cache-to: type=gha,mode=max
|
||||||
|
|
||||||
- name: Build and push
|
|
||||||
uses: docker/build-push-action@v6
|
|
||||||
with:
|
|
||||||
context: .
|
|
||||||
push: ${{ !github.event.pull_request.head.repo.fork && github.actor != 'dependabot[bot]' }}
|
|
||||||
file: ./Dockerfile
|
|
||||||
tags: ${{ steps.meta.outputs.tags }}
|
|
||||||
labels: ${{ steps.meta.outputs.labels }}
|
|
||||||
|
40
Dockerfile.github-actions
Normal file
40
Dockerfile.github-actions
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
FROM docker.io/oven/bun:1-alpine AS build
|
||||||
|
|
||||||
|
# go to work folder
|
||||||
|
WORKDIR /usr/src/app
|
||||||
|
|
||||||
|
# allow bun user to edit folder
|
||||||
|
RUN chown -R bun:bun .
|
||||||
|
|
||||||
|
USER bun
|
||||||
|
|
||||||
|
ADD --chown=bun:bun server/package.json server/bun.lockb ./server/
|
||||||
|
|
||||||
|
# install prod deps dependencies
|
||||||
|
RUN cd server && \
|
||||||
|
bun install --frozen-install --production
|
||||||
|
|
||||||
|
# go to another VM
|
||||||
|
FROM docker.io/oven/bun:1-alpine AS prod
|
||||||
|
|
||||||
|
# inform software to be in production
|
||||||
|
ENV NODE_ENV=production
|
||||||
|
|
||||||
|
# run as non root user
|
||||||
|
USER bun
|
||||||
|
|
||||||
|
# go to work folder
|
||||||
|
WORKDIR /usr/src/app
|
||||||
|
|
||||||
|
# copy from build image
|
||||||
|
COPY --chown=bun:bun ./server/public ./public
|
||||||
|
COPY --chown=bun:bun ./server/package.json ./package.json
|
||||||
|
COPY --chown=bun:bun --from=build /usr/src/app/server/node_modules ./node_modules
|
||||||
|
COPY --chown=bun:bun ./server/src ./src
|
||||||
|
COPY --chown=bun:bun ./server/generated ./generated
|
||||||
|
|
||||||
|
# Expose port
|
||||||
|
EXPOSE 3000
|
||||||
|
|
||||||
|
# run it !
|
||||||
|
CMD ["bun", "src/index.ts"]
|
Reference in New Issue
Block a user