chore: Add database migration dockerfile (#2122)

This commit is contained in:
Matti Nannt
2024-02-24 17:08:57 +01:00
committed by GitHub
parent 78ed91b7c3
commit 338b21620b
4 changed files with 113 additions and 1 deletions
@@ -0,0 +1,70 @@
name: Docker for Data Migrations
# This workflow uses actions that are not certified by GitHub.
# They are provided by a third-party and are governed by
# separate terms of service, privacy policy, and support
# documentation.
on:
workflow_dispatch:
push:
tags:
- "v*"
env:
# Use docker.io for Docker Hub if empty
REGISTRY: ghcr.io
IMAGE_NAME: formbricks/data-migrations
DATABASE_URL: "postgresql://postgres:postgres@postgres:5432/formbricks?schema=public"
jobs:
build-and-push:
runs-on: ubuntu-latest
permissions:
contents: read
packages: write
# This is used to complete the identity challenge
# with sigstore/fulcio when running outside of PRs.
id-token: write
steps:
- name: Checkout repository
uses: actions/checkout@v3
- name: Install cosign
if: github.event_name != 'pull_request'
uses: sigstore/cosign-installer@6e04d228eb30da1757ee4e1dd75a0ec73a653e06 #v3.1.1
with:
cosign-release: "v2.1.1"
- name: Log in to GitHub Container Registry
uses: docker/login-action@v3
with:
registry: ${{ env.REGISTRY }}
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Extract Docker metadata
id: meta
uses: docker/metadata-action@v5
with:
images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}
tags: |
type=ref,event=tag
type=raw,value=${{ github.ref_name }}
- name: Build and push Docker image
uses: docker/build-push-action@v3
with:
context: .
file: ./packages/database/Dockerfile
push: true
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
build-args: |
DATABASE_URL=${{ env.DATABASE_URL }}
- name: Sign the published Docker image
if: ${{ github.event_name != 'pull_request' }}
run: |
cosign sign --yes ghcr.io/${{ env.IMAGE_NAME }}:${{ github.ref_name }}
+38
View File
@@ -0,0 +1,38 @@
FROM node:20-alpine AS base
#
## step 1: Prune monorepo
#
FROM base AS builder
RUN apk add --no-cache libc6-compat
RUN apk update
# Set working directory
WORKDIR /app
RUN yarn global add turbo
COPY . .
RUN turbo prune @formbricks/database --docker
#
## step 2: Install & build
#
FROM base AS runner
WORKDIR /app
# Enable corepack and prepare pnpm
RUN corepack enable && corepack prepare pnpm@latest --activate
ARG DATABASE_URL
ENV DATABASE_URL=$DATABASE_URL
ARG UPGRADE_TO_VERSION
ENV UPGRADE_TO_VERSION=$UPGRADE_TO_VERSION
# Install necessary build tools and compilers
# RUN apk update && apk add --no-cache g++ cmake make gcc python3 openssl-dev
COPY --from=builder /app/out/full/ .
RUN pnpm install
CMD ["sh", "-c", "cd packages/database && pnpm data-migration:${UPGRADE_TO_VERSION}"]
+2 -1
View File
@@ -23,7 +23,7 @@
"lint": "eslint ./src --fix",
"post-install": "pnpm generate",
"predev": "pnpm generate",
"data-migration:advanced-targeting": "ts-node ./migrations/20240207041922_advanced_targeting/data-migration.ts"
"data-migration:1.6": "ts-node ./migrations/20240207041922_advanced_targeting/data-migration.ts"
},
"dependencies": {
"@prisma/client": "^5.8.1",
@@ -37,6 +37,7 @@
"prisma": "^5.8.1",
"prisma-dbml-generator": "^0.10.0",
"prisma-json-types-generator": "^3.0.3",
"ts-node": "^10.9.2",
"zod": "^3.22.4",
"zod-prisma": "^0.5.4"
}
+3
View File
@@ -500,6 +500,9 @@ importers:
prisma-json-types-generator:
specifier: ^3.0.3
version: 3.0.3(prisma@5.8.1)(typescript@5.3.3)
ts-node:
specifier: ^10.9.2
version: 10.9.2(@types/node@20.11.6)(typescript@5.3.3)
zod:
specifier: ^3.22.4
version: 3.22.4