From 34fbcb8a1eeef8e0aec2c600184c1b7c6978dcb5 Mon Sep 17 00:00:00 2001 From: JohanHjelsethStorstad <82723971+JohanHjelsethStorstad@users.noreply.github.com> Date: Sat, 14 Oct 2023 14:46:47 +0200 Subject: [PATCH 01/14] chore: chenge .dockerignore for prisma to be logical --- .dockerignore | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/.dockerignore b/.dockerignore index 93d0cdcdf..98ba252ae 100644 --- a/.dockerignore +++ b/.dockerignore @@ -3,6 +3,5 @@ npm-debug.log build .next -/src/prisma -!/src/prisma/schema.prisma -!/src/prisma/index.js \ No newline at end of file +# prisma +src/prisma/migrations \ No newline at end of file From de072553d2cdbd6ff4a8432867b73d4c1586efb6 Mon Sep 17 00:00:00 2001 From: JohanHjelsethStorstad <82723971+JohanHjelsethStorstad@users.noreply.github.com> Date: Sat, 14 Oct 2023 14:52:17 +0200 Subject: [PATCH 02/14] fix: nextConfig option was depricated --- next.config.js | 9 --------- 1 file changed, 9 deletions(-) diff --git a/next.config.js b/next.config.js index d12b6804b..6c6e8555d 100644 --- a/next.config.js +++ b/next.config.js @@ -2,15 +2,6 @@ const path = require('path') const nextConfig = { - //Add some random config because of some issue with hot reload of next in docker - //This config might not be neccessary on later next releases - webpackDevMiddleware: config => { - config.watchOptions = { - poll: 800, - aggregateTimeout: 300, - } - return config - }, sassOptions: { includePaths: [path.join(__dirname, 'src/styles')], }, From 5c2ab6f9d4876bdc9e67cdc38e688a20d7319f47 Mon Sep 17 00:00:00 2001 From: JohanHjelsethStorstad <82723971+JohanHjelsethStorstad@users.noreply.github.com> Date: Sat, 14 Oct 2023 15:03:22 +0200 Subject: [PATCH 03/14] chore: migrate to the new next metadata-api --- src/app/layout.js | 15 +-------------- 1 file changed, 1 insertion(+), 14 deletions(-) diff --git a/src/app/layout.js b/src/app/layout.js index c860137a9..ac44f5a56 100644 --- a/src/app/layout.js +++ b/src/app/layout.js @@ -1,6 +1,4 @@ import { Inter } from 'next/font/google' -import Head from 'next/head' -import { v4 as uuid } from 'uuid' import NavBar from '@/components/NavBar/NavBar' import MobileNavBar from '@/components/NavBar/MobileNavBar' @@ -18,24 +16,13 @@ const inter = Inter({ subsets: ['latin'] }) export const metadata = { title: 'projectnext', description: '', + charset: 'utf-8', } export default function RootLayout({ children }) { return ( - - - - - - - - - - - -
From 4880a56f75ba9ad1901b3d095dd6db2cf39b611f Mon Sep 17 00:00:00 2001 From: Paulius Juzenas <59730296+Paulijuz@users.noreply.github.com> Date: Sun, 15 Oct 2023 03:07:25 +0200 Subject: [PATCH 04/14] fix: prisma migration in docker cli --- Dockerfile | 3 +-- Dockerfile.dev | 2 +- package.json | 3 ++- 3 files changed, 4 insertions(+), 4 deletions(-) diff --git a/Dockerfile b/Dockerfile index 86df5d074..779198102 100644 --- a/Dockerfile +++ b/Dockerfile @@ -8,5 +8,4 @@ RUN npm ci COPY ./ ./ -RUN npm run build -CMD ["npm", "run", "docker:migrate:dev"] \ No newline at end of file +CMD ["npm", "run", "migrate:build:start"] \ No newline at end of file diff --git a/Dockerfile.dev b/Dockerfile.dev index b096ce959..052495f8d 100644 --- a/Dockerfile.dev +++ b/Dockerfile.dev @@ -6,4 +6,4 @@ RUN npm ci COPY ./ ./ -CMD ["npm", "run", "docker:migrate:dev"] \ No newline at end of file +CMD ["npm", "run", "migrate:dev"] \ No newline at end of file diff --git a/package.json b/package.json index 3cd14e834..0ea32eda6 100644 --- a/package.json +++ b/package.json @@ -7,7 +7,8 @@ "build": "next build", "start": "next start", "lint": "next lint", - "docker:migrate:dev": "npx prisma migrate dev --name init && next dev" + "migrate:dev": "npx prisma migrate deploy && next dev", + "migrate:build:start": "npx prisma migrate deploy && next build && next start" }, "prisma": { "schema": "src/prisma/schema.prisma" From b721589fe717f0765863b41d9b1d1c1171415816 Mon Sep 17 00:00:00 2001 From: JohanHjelsethStorstad <82723971+JohanHjelsethStorstad@users.noreply.github.com> Date: Thu, 19 Oct 2023 18:12:22 +0200 Subject: [PATCH 05/14] refactor: add stages to Dockerfile for prod and dev. Prisma now generates correctly in both prod and dev --- Dockerfile | 28 +++++++++++++++----- Dockerfile.dev | 9 ------- docker-compose.dev.yml | 3 ++- docker-compose.yml | 5 ++++ package.json | 3 +-- scripts/start.dev.sh | 3 --- scripts/start.sh | 3 --- src/app/components/Loader/Loader.js | 13 +++++++++ src/app/components/Loader/Loader.module.scss | 5 ++++ 9 files changed, 47 insertions(+), 25 deletions(-) delete mode 100644 Dockerfile.dev delete mode 100644 scripts/start.dev.sh delete mode 100644 scripts/start.sh create mode 100644 src/app/components/Loader/Loader.js create mode 100644 src/app/components/Loader/Loader.module.scss diff --git a/Dockerfile b/Dockerfile index 86df5d074..7dabfa75c 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,12 +1,26 @@ -FROM node:18-alpine - +FROM node:18-alpine AS base WORKDIR /usr/src/app - -# Install node modules COPY package*.json ./ RUN npm ci +COPY . . +############################################################ +FROM node:18-alpine AS prod +WORKDIR /usr/src/app +COPY --from=base /usr/src/app/ . -COPY ./ ./ - +RUN npx prisma generate RUN npm run build -CMD ["npm", "run", "docker:migrate:dev"] \ No newline at end of file + +CMD ["npm", "run", "start"] +############################################################ +FROM node:18-alpine AS dev +WORKDIR /usr/src/app +COPY --from=base /usr/src/app/ . + +RUN npx prisma generate +CMD ["npm", "run", "dev"] + + + + + diff --git a/Dockerfile.dev b/Dockerfile.dev deleted file mode 100644 index b096ce959..000000000 --- a/Dockerfile.dev +++ /dev/null @@ -1,9 +0,0 @@ -FROM node:18-alpine - -WORKDIR /usr/src/app -COPY package*.json ./ -RUN npm ci - -COPY ./ ./ - -CMD ["npm", "run", "docker:migrate:dev"] \ No newline at end of file diff --git a/docker-compose.dev.yml b/docker-compose.dev.yml index 30c5d6fef..eae9e0433 100644 --- a/docker-compose.dev.yml +++ b/docker-compose.dev.yml @@ -4,7 +4,8 @@ services: projectnext: build: context: ./ - dockerfile: ./Dockerfile.dev + dockerfile: ./Dockerfile + target: dev ports: - 3000:3000 volumes: diff --git a/docker-compose.yml b/docker-compose.yml index b66efc651..66db6af3d 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -5,12 +5,17 @@ services: build: context: ./ dockerfile: ./Dockerfile + target: prod ports: - 3000:3000 environment: DB_URI: ${DB_URI} GOOGLE_MAPS_API_KEY: ${GOOGLE_MAPS_API_KEY} NODE_ENV: production + depends_on: + - db + links: + - db db: image: postgres:16.0-alpine diff --git a/package.json b/package.json index 3cd14e834..638d92cca 100644 --- a/package.json +++ b/package.json @@ -6,8 +6,7 @@ "dev": "next dev", "build": "next build", "start": "next start", - "lint": "next lint", - "docker:migrate:dev": "npx prisma migrate dev --name init && next dev" + "lint": "next lint" }, "prisma": { "schema": "src/prisma/schema.prisma" diff --git a/scripts/start.dev.sh b/scripts/start.dev.sh deleted file mode 100644 index 9b096ac87..000000000 --- a/scripts/start.dev.sh +++ /dev/null @@ -1,3 +0,0 @@ -#!/bin/sh - -npx prisma migrate dev --name init && npm run dev \ No newline at end of file diff --git a/scripts/start.sh b/scripts/start.sh deleted file mode 100644 index c292369a6..000000000 --- a/scripts/start.sh +++ /dev/null @@ -1,3 +0,0 @@ -#!/bin/sh - -echo "Not implemented yet" \ No newline at end of file diff --git a/src/app/components/Loader/Loader.js b/src/app/components/Loader/Loader.js new file mode 100644 index 000000000..1b0b61a2a --- /dev/null +++ b/src/app/components/Loader/Loader.js @@ -0,0 +1,13 @@ +import styles from './Loader.module.scss' +import logo from '@/images/logo_simple.png' +import Image from 'next/image' + +function Loader() { + return ( +
+ +
+ ) +} + +export default Loader \ No newline at end of file diff --git a/src/app/components/Loader/Loader.module.scss b/src/app/components/Loader/Loader.module.scss new file mode 100644 index 000000000..b47851f3a --- /dev/null +++ b/src/app/components/Loader/Loader.module.scss @@ -0,0 +1,5 @@ +@use '@/styles/ohma'; + +.Loader { + +} \ No newline at end of file From bc7518145224e8cc0c8535f25c00321f21450726 Mon Sep 17 00:00:00 2001 From: JohanHjelsethStorstad <82723971+JohanHjelsethStorstad@users.noreply.github.com> Date: Thu, 19 Oct 2023 18:28:14 +0200 Subject: [PATCH 06/14] fix: deleted wrong Dockerfile --- Dockerfile | 21 +++++++++++++++++++++ Dockerfile.dev | 9 --------- 2 files changed, 21 insertions(+), 9 deletions(-) create mode 100644 Dockerfile delete mode 100644 Dockerfile.dev diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 000000000..664182c90 --- /dev/null +++ b/Dockerfile @@ -0,0 +1,21 @@ +FROM node:18-alpine AS base +WORKDIR /usr/src/app +COPY package*.json ./ +RUN npm ci +COPY . . +############################################################ +FROM node:18-alpine AS prod +WORKDIR /usr/src/app +COPY --from=base /usr/src/app/ . + +RUN npx prisma generate +RUN npm run build + +CMD ["npm", "run", "start"] +############################################################ +FROM node:18-alpine AS dev +WORKDIR /usr/src/app +COPY --from=base /usr/src/app/ . + +RUN npx prisma generate +CMD ["npm", "run", "dev"] \ No newline at end of file diff --git a/Dockerfile.dev b/Dockerfile.dev deleted file mode 100644 index 052495f8d..000000000 --- a/Dockerfile.dev +++ /dev/null @@ -1,9 +0,0 @@ -FROM node:18-alpine - -WORKDIR /usr/src/app -COPY package*.json ./ -RUN npm ci - -COPY ./ ./ - -CMD ["npm", "run", "migrate:dev"] \ No newline at end of file From 36f76615dbba8e34afac03a426011edf1fc88097 Mon Sep 17 00:00:00 2001 From: JohanHjelsethStorstad <82723971+JohanHjelsethStorstad@users.noreply.github.com> Date: Tue, 24 Oct 2023 14:20:33 +0200 Subject: [PATCH 07/14] feat: dev now works --- Dockerfile | 3 ++- docker-compose.dev.yml | 23 ++++++++++++++++++++++- docker-compose.yml | 18 ++++++++++++++++++ src/app/api/users/route.js | 7 +++++-- src/prisma/Dockerfile | 21 +++++++++++++++++++++ 5 files changed, 68 insertions(+), 4 deletions(-) create mode 100644 src/prisma/Dockerfile diff --git a/Dockerfile b/Dockerfile index 664182c90..78d2ad585 100644 --- a/Dockerfile +++ b/Dockerfile @@ -9,8 +9,8 @@ WORKDIR /usr/src/app COPY --from=base /usr/src/app/ . RUN npx prisma generate -RUN npm run build +RUN npm run build CMD ["npm", "run", "start"] ############################################################ FROM node:18-alpine AS dev @@ -18,4 +18,5 @@ WORKDIR /usr/src/app COPY --from=base /usr/src/app/ . RUN npx prisma generate + CMD ["npm", "run", "dev"] \ No newline at end of file diff --git a/docker-compose.dev.yml b/docker-compose.dev.yml index eae9e0433..02b2f496c 100644 --- a/docker-compose.dev.yml +++ b/docker-compose.dev.yml @@ -10,12 +10,15 @@ services: - 3000:3000 volumes: - ./src:/usr/src/app/src + - ./package.json:/usr/src/app/package.json + - ./package-lock.json:/usr/src/app/package-lock.json environment: - DB_URI: ${DB_URI} + DB_URI: postgresql://${DB_USERNAME}:${DB_PASSWORD}@localhost:5432/${DB_NAME} GOOGLE_MAPS_API_KEY: ${GOOGLE_MAPS_API_KEY} NODE_ENV: development depends_on: - db + - prisma links: - db @@ -30,6 +33,24 @@ services: POSTGRES_PASSWORD: ${DB_PASSWORD} volumes: - devdb:/var/lib/postgresql/data + healthcheck: + test: ["CMD-SHELL", "sh -c 'pg_isready -U ${DB_USERNAME} -d ${DB_NAME}'"] + interval: 3s + timeout: 3s + retries: 10 + + prisma: + build: + context: ./src/prisma + dockerfile: ./Dockerfile + target: dev + environment: + DB_URI: postgresql://${DB_USERNAME}:${DB_PASSWORD}@db:5432/${DB_NAME} + depends_on: + db: + condition: service_healthy + links: + - db volumes: devdb: diff --git a/docker-compose.yml b/docker-compose.yml index 66db6af3d..cb9453fa2 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -28,6 +28,24 @@ services: POSTGRES_PASSWORD: ${DB_PASSWORD} volumes: - proddb:/var/lib/postgresql/data + healthcheck: + test: ["CMD-SHELL", "sh -c 'pg_isready -U ${DB_USERNAME} -d ${DB_NAME}'"] + interval: 3s + timeout: 3s + retries: 10 + + prisma: + build: + context: ./src/prisma + dockerfile: ./Dockerfile + target: dev + environment: + DB_URI: postgresql://${DB_USERNAME}:${DB_PASSWORD}@db:5432/${DB_NAME} + depends_on: + db: + condition: service_healthy + links: + - db volumes: proddb: diff --git a/src/app/api/users/route.js b/src/app/api/users/route.js index f1626c41d..a8c2dea46 100644 --- a/src/app/api/users/route.js +++ b/src/app/api/users/route.js @@ -32,8 +32,11 @@ export async function POST(req) { if ( error instanceof Prisma.PrismaClientKnownRequestError && error.code === 'P2002' - ) { + ) + { return Response.json({}, { status: 409 }) - } + } + + throw error } } \ No newline at end of file diff --git a/src/prisma/Dockerfile b/src/prisma/Dockerfile new file mode 100644 index 000000000..430e3f4cb --- /dev/null +++ b/src/prisma/Dockerfile @@ -0,0 +1,21 @@ +#This container is responisble for running migrations + +FROM node:18-alpine AS base +WORKDIR /usr/src/app +RUN npm i prisma +COPY . . + +################################################### +FROM node:18-alpine AS prod +WORKDIR /usr/src/app +COPY --from=base /usr/src/app . + +CMD ["npx", "prisma", "migrate", "dev"] + +################################################### +FROM node:18-alpine AS dev + +WORKDIR /usr/src/app +COPY --from=base /usr/src/app . + +CMD ["npx", "prisma", "migrate", "dev"] \ No newline at end of file From 429a373a4e636395d7fb4266250395f34e4317f0 Mon Sep 17 00:00:00 2001 From: JohanHjelsethStorstad <82723971+JohanHjelsethStorstad@users.noreply.github.com> Date: Wed, 25 Oct 2023 19:06:49 +0200 Subject: [PATCH 08/14] fix: docker-compose.yml target: prod --- docker-compose.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docker-compose.yml b/docker-compose.yml index cb9453fa2..088f05b11 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -38,7 +38,7 @@ services: build: context: ./src/prisma dockerfile: ./Dockerfile - target: dev + target: prod environment: DB_URI: postgresql://${DB_USERNAME}:${DB_PASSWORD}@db:5432/${DB_NAME} depends_on: From 311676696cb23c68c6db590d04baf9262e61ecb1 Mon Sep 17 00:00:00 2001 From: JohanHjelsethStorstad <82723971+JohanHjelsethStorstad@users.noreply.github.com> Date: Wed, 25 Oct 2023 20:54:19 +0200 Subject: [PATCH 09/14] fix: add name to migration to make it work always --- .dockerignore | 4 ++++ Dockerfile | 10 ++++++---- default.env | 2 -- docker-compose.dev.yml | 5 ++++- docker-compose.yml | 27 ++++++++++++++------------- src/prisma/Dockerfile | 13 ++++++------- src/prisma/schema.prisma | 5 +---- 7 files changed, 35 insertions(+), 31 deletions(-) diff --git a/.dockerignore b/.dockerignore index 98ba252ae..8ba188cba 100644 --- a/.dockerignore +++ b/.dockerignore @@ -3,5 +3,9 @@ npm-debug.log build .next +#you should be explicit in docker-compose about what env-vars should be loaded into a container +.env +default.env + # prisma src/prisma/migrations \ No newline at end of file diff --git a/Dockerfile b/Dockerfile index 78d2ad585..85995ab7d 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,15 +1,19 @@ FROM node:18-alpine AS base WORKDIR /usr/src/app + COPY package*.json ./ RUN npm ci + +RUN mkdir -p src/prisma +COPY src/prisma/schema.prisma ./src/prisma/ +RUN npx prisma generate + COPY . . ############################################################ FROM node:18-alpine AS prod WORKDIR /usr/src/app COPY --from=base /usr/src/app/ . -RUN npx prisma generate - RUN npm run build CMD ["npm", "run", "start"] ############################################################ @@ -17,6 +21,4 @@ FROM node:18-alpine AS dev WORKDIR /usr/src/app COPY --from=base /usr/src/app/ . -RUN npx prisma generate - CMD ["npm", "run", "dev"] \ No newline at end of file diff --git a/default.env b/default.env index 014f32513..449048bff 100644 --- a/default.env +++ b/default.env @@ -2,5 +2,3 @@ GOOGLE_MAPS_API_KEY=HMMMMMMMMM DB_NAME=devdb DB_USERNAME=user DB_PASSWORD=password - -DB_URI="postgresql://${DB_USERNAME}:${DB_PASSWORD}@db:5432/${DB_NAME}" \ No newline at end of file diff --git a/docker-compose.dev.yml b/docker-compose.dev.yml index 02b2f496c..d5504020f 100644 --- a/docker-compose.dev.yml +++ b/docker-compose.dev.yml @@ -12,8 +12,9 @@ services: - ./src:/usr/src/app/src - ./package.json:/usr/src/app/package.json - ./package-lock.json:/usr/src/app/package-lock.json + - ./src/prisma/schema.prisma:/usr/src/app/src/prisma/schema.prisma environment: - DB_URI: postgresql://${DB_USERNAME}:${DB_PASSWORD}@localhost:5432/${DB_NAME} + DB_URI: postgresql://${DB_USERNAME}:${DB_PASSWORD}@db:5432/${DB_NAME} GOOGLE_MAPS_API_KEY: ${GOOGLE_MAPS_API_KEY} NODE_ENV: development depends_on: @@ -46,6 +47,8 @@ services: target: dev environment: DB_URI: postgresql://${DB_USERNAME}:${DB_PASSWORD}@db:5432/${DB_NAME} + volumes: + - ./src/prisma/schema.prisma:/usr/src/app/schema.prisma depends_on: db: condition: service_healthy diff --git a/docker-compose.yml b/docker-compose.yml index 088f05b11..e12662e5d 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -9,11 +9,12 @@ services: ports: - 3000:3000 environment: - DB_URI: ${DB_URI} + DB_URI: postgresql://${DB_USERNAME}:${DB_PASSWORD}@db:5432/${DB_NAME} GOOGLE_MAPS_API_KEY: ${GOOGLE_MAPS_API_KEY} NODE_ENV: production depends_on: - db + - prisma links: - db @@ -34,18 +35,18 @@ services: timeout: 3s retries: 10 - prisma: - build: - context: ./src/prisma - dockerfile: ./Dockerfile - target: prod - environment: - DB_URI: postgresql://${DB_USERNAME}:${DB_PASSWORD}@db:5432/${DB_NAME} - depends_on: - db: - condition: service_healthy - links: - - db + prisma: + build: + context: ./src/prisma + dockerfile: ./Dockerfile + target: prod + environment: + DB_URI: postgresql://${DB_USERNAME}:${DB_PASSWORD}@db:5432/${DB_NAME} + depends_on: + db: + condition: service_healthy + links: + - db volumes: proddb: diff --git a/src/prisma/Dockerfile b/src/prisma/Dockerfile index 430e3f4cb..1b6d4072d 100644 --- a/src/prisma/Dockerfile +++ b/src/prisma/Dockerfile @@ -1,21 +1,20 @@ #This container is responisble for running migrations - FROM node:18-alpine AS base WORKDIR /usr/src/app RUN npm i prisma -COPY . . +RUN npx prisma init +COPY schema.prisma ./ -################################################### +######################################################## FROM node:18-alpine AS prod WORKDIR /usr/src/app COPY --from=base /usr/src/app . -CMD ["npx", "prisma", "migrate", "dev"] +CMD ["npx", "prisma", "migrate", "deploy", "--name", "docker-migration", "--skip-generate"] -################################################### +######################################################## FROM node:18-alpine AS dev - WORKDIR /usr/src/app COPY --from=base /usr/src/app . -CMD ["npx", "prisma", "migrate", "dev"] \ No newline at end of file +CMD ["npx", "prisma", "migrate", "dev", "--name" , "docker-migration", "--skip-generate"] \ No newline at end of file diff --git a/src/prisma/schema.prisma b/src/prisma/schema.prisma index 41f9512d3..a415b9dd2 100644 --- a/src/prisma/schema.prisma +++ b/src/prisma/schema.prisma @@ -1,6 +1,3 @@ -// This is your Prisma schema file, -// learn more about it in the docs: https://pris.ly/d/prisma-schema - generator client { provider = "prisma-client-js" } @@ -17,4 +14,4 @@ model User { email String @unique @@map("users") -} \ No newline at end of file +} From 9af42bec3e2ce6d5d619d46884209661ba9e6fa8 Mon Sep 17 00:00:00 2001 From: JohanHjelsethStorstad <82723971+JohanHjelsethStorstad@users.noreply.github.com> Date: Wed, 25 Oct 2023 21:09:49 +0200 Subject: [PATCH 10/14] fix: migrate deploy invalid options --- src/prisma/Dockerfile | 3 ++- src/prisma/seed.js | 17 +++++++++++++++++ 2 files changed, 19 insertions(+), 1 deletion(-) create mode 100644 src/prisma/seed.js diff --git a/src/prisma/Dockerfile b/src/prisma/Dockerfile index 1b6d4072d..cb3033217 100644 --- a/src/prisma/Dockerfile +++ b/src/prisma/Dockerfile @@ -10,7 +10,8 @@ FROM node:18-alpine AS prod WORKDIR /usr/src/app COPY --from=base /usr/src/app . -CMD ["npx", "prisma", "migrate", "deploy", "--name", "docker-migration", "--skip-generate"] +#DEPLOY NOT IMPLEMENTED YET: should be npy prisma migrate deploy. +CMD ["npx", "prisma", "migrate", "dev", "--name" , "docker-migration", "--skip-generate"] ######################################################## FROM node:18-alpine AS dev diff --git a/src/prisma/seed.js b/src/prisma/seed.js new file mode 100644 index 000000000..4650c44ff --- /dev/null +++ b/src/prisma/seed.js @@ -0,0 +1,17 @@ +import { PrismaClient } from '@prisma/client' +const prisma = new PrismaClient() +async function main() { + const harambe = await prisma.user.upsert({ + create: { + email: 'harambe@harambesen.io', + }, + }) + console.log({ alice }) +} +main().then(async () => { + await prisma.$disconnect() +}).catch(async (e) => { + console.error(e) + await prisma.$disconnect() + process.exit(1) +}) \ No newline at end of file From 30821a2e17a806b5db22a358a245542dc147b026 Mon Sep 17 00:00:00 2001 From: JohanHjelsethStorstad <82723971+JohanHjelsethStorstad@users.noreply.github.com> Date: Wed, 25 Oct 2023 23:20:58 +0200 Subject: [PATCH 11/14] feat: add seeding --- src/prisma/Dockerfile | 7 ++++++- src/prisma/seed.js | 14 ++++++++++++-- 2 files changed, 18 insertions(+), 3 deletions(-) diff --git a/src/prisma/Dockerfile b/src/prisma/Dockerfile index cb3033217..6d324261c 100644 --- a/src/prisma/Dockerfile +++ b/src/prisma/Dockerfile @@ -1,6 +1,7 @@ #This container is responisble for running migrations FROM node:18-alpine AS base WORKDIR /usr/src/app +RUN npm init es6 RUN npm i prisma RUN npx prisma init COPY schema.prisma ./ @@ -18,4 +19,8 @@ FROM node:18-alpine AS dev WORKDIR /usr/src/app COPY --from=base /usr/src/app . -CMD ["npx", "prisma", "migrate", "dev", "--name" , "docker-migration", "--skip-generate"] \ No newline at end of file +RUN npm install @prisma/client +RUN npx prisma generate +COPY seed.js ./ + +CMD ["/bin/sh", "-c", "npx prisma migrate dev --name docker-migration --skip-generate; node seed.js"] \ No newline at end of file diff --git a/src/prisma/seed.js b/src/prisma/seed.js index 4650c44ff..61117e49d 100644 --- a/src/prisma/seed.js +++ b/src/prisma/seed.js @@ -1,12 +1,22 @@ import { PrismaClient } from '@prisma/client' const prisma = new PrismaClient() + +console.log("seed starting...") async function main() { const harambe = await prisma.user.upsert({ + where: { + email: 'harambe@harambesen.io' + }, + update: { + + }, create: { - email: 'harambe@harambesen.io', + firstname: "Harambe", + lastname: "Harambesen", + email: 'harambe@harambesen.io', }, }) - console.log({ alice }) + console.log({ harambe }) } main().then(async () => { await prisma.$disconnect() From 7070ede9cd0faf8f7699ee93759f544941c015af Mon Sep 17 00:00:00 2001 From: JohanHjelsethStorstad <82723971+JohanHjelsethStorstad@users.noreply.github.com> Date: Thu, 26 Oct 2023 10:57:14 +0200 Subject: [PATCH 12/14] chore: update readme --- README.md | 30 ++++++++++++++++++++++++++++-- 1 file changed, 28 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index 0eea1ed8f..8e3ae09f0 100644 --- a/README.md +++ b/README.md @@ -1,23 +1,49 @@ ## Config + You need a .env file (this file is gitignored). You can find default values in default.env. Either copy theese to ./.env file or use the --env-file default.env flag when building ## Development -You have to run veven alongside this project to get access to the api and database. So have veven running in its docker-containers. -Then run: +Have the docker deamon running, then run: + ```bash docker-compose -f docker-compose.dev.yml up --build ``` +#### Working with the DB + +To remigrate the db, just rerun the prisma container +To regenerate the client-libary from the schema file run: + +```bash +npx prisma generate +``` + +in the projectnext container + +#### Reinstalling node_modules + +Since we are using volumes in dev, the dev container should keep itself up to date with your working directory. But you will need to reinstall packages manually in projectnext upon changing package.json. Run: + +```bash +npm ci +``` + +inside projectnext-container + ## Production + This project is not meant to be deployed, but a build can be made by running + ```bash docker-compose up --build ``` ## Lint + To lint the project run + ```bash npm run lint ``` From 8ec22fe63c07546dddc274d97c979fea06349a48 Mon Sep 17 00:00:00 2001 From: Paulius Juzenas <59730296+Paulijuz@users.noreply.github.com> Date: Thu, 26 Oct 2023 15:47:11 +0200 Subject: [PATCH 13/14] chore: add seed.js to prisma config --- package.json | 3 ++- src/prisma/Dockerfile | 2 +- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/package.json b/package.json index 638d92cca..1e1e63c3c 100644 --- a/package.json +++ b/package.json @@ -9,7 +9,8 @@ "lint": "next lint" }, "prisma": { - "schema": "src/prisma/schema.prisma" + "schema": "src/prisma/schema.prisma", + "seed": "node src/prisma/seed.js" }, "dependencies": { "@fortawesome/fontawesome-svg-core": "^6.4.2", diff --git a/src/prisma/Dockerfile b/src/prisma/Dockerfile index 6d324261c..f20d6f0da 100644 --- a/src/prisma/Dockerfile +++ b/src/prisma/Dockerfile @@ -23,4 +23,4 @@ RUN npm install @prisma/client RUN npx prisma generate COPY seed.js ./ -CMD ["/bin/sh", "-c", "npx prisma migrate dev --name docker-migration --skip-generate; node seed.js"] \ No newline at end of file +CMD ["/bin/sh", "-c", "npx prisma migrate dev --name docker-migration --skip-generate; npx prisma db seed"] \ No newline at end of file From d2ef394cb6f8d6dae96de356ef5ca0d3c60b1e2a Mon Sep 17 00:00:00 2001 From: Paulius Juzenas <59730296+Paulijuz@users.noreply.github.com> Date: Thu, 26 Oct 2023 16:22:12 +0200 Subject: [PATCH 14/14] chore: undo seed change in prisma dockerfile --- src/prisma/Dockerfile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/prisma/Dockerfile b/src/prisma/Dockerfile index f20d6f0da..6d324261c 100644 --- a/src/prisma/Dockerfile +++ b/src/prisma/Dockerfile @@ -23,4 +23,4 @@ RUN npm install @prisma/client RUN npx prisma generate COPY seed.js ./ -CMD ["/bin/sh", "-c", "npx prisma migrate dev --name docker-migration --skip-generate; npx prisma db seed"] \ No newline at end of file +CMD ["/bin/sh", "-c", "npx prisma migrate dev --name docker-migration --skip-generate; node seed.js"] \ No newline at end of file