From f6d1461c72fd461909ace514aafcf945fee0a320 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Martin=20=C5=A0o=C5=A1i=C4=87?= Date: Wed, 24 Jan 2024 14:42:18 +0100 Subject: [PATCH] Add server setup to proper SDK gen (#1667) --- waspc/data/Generator/templates/sdk/package.json | 2 ++ .../Generator/templates/sdk/server/types/index.ts | 12 ++++++++++++ waspc/data/Generator/templates/server/src/server.ts | 2 +- .../Generator/templates/server/src/types/index.ts | 13 ------------- .../todo-typescript/.wasp/out/sdk/wasp/package.json | 1 + waspc/examples/todo-typescript/main.wasp | 1 + waspc/examples/todo-typescript/src/serverSetup.ts | 8 ++++++++ waspc/src/Wasp/Generator/SdkGenerator.hs | 5 +++++ waspc/src/Wasp/Generator/ServerGenerator.hs | 4 +--- 9 files changed, 31 insertions(+), 17 deletions(-) create mode 100644 waspc/data/Generator/templates/sdk/server/types/index.ts diff --git a/waspc/data/Generator/templates/sdk/package.json b/waspc/data/Generator/templates/sdk/package.json index 47ed5f58af..092ce20093 100644 --- a/waspc/data/Generator/templates/sdk/package.json +++ b/waspc/data/Generator/templates/sdk/package.json @@ -90,6 +90,8 @@ "./server/dbClient": "./dist/server/dbClient.js", {=! Used by users and by our code, documented. =} "./server/config": "./dist/server/config.js", + {=! Used by users and by our code, documented. =} + "./server/types": "./dist/server/types/index.js", {=! Parts are used by users, documented. Parts are probably used by our code, undocumented (but accessible). =} "./server/utils": "./dist/server/utils.js", {=! Used by our code, uncodumented (but accessible) for users. =} diff --git a/waspc/data/Generator/templates/sdk/server/types/index.ts b/waspc/data/Generator/templates/sdk/server/types/index.ts new file mode 100644 index 0000000000..fda96a4528 --- /dev/null +++ b/waspc/data/Generator/templates/sdk/server/types/index.ts @@ -0,0 +1,12 @@ +import { type Application } from 'express' +import { Server } from 'http' + +export type ServerSetupFn = (context: ServerSetupFnContext) => Promise + +export type ServerSetupFnContext = { + app: Application, + server: Server, +} + +export type { Application } from 'express' +export type { Server } from 'http' diff --git a/waspc/data/Generator/templates/server/src/server.ts b/waspc/data/Generator/templates/server/src/server.ts index 858011c482..e4b16898b6 100644 --- a/waspc/data/Generator/templates/server/src/server.ts +++ b/waspc/data/Generator/templates/server/src/server.ts @@ -6,7 +6,7 @@ import config from 'wasp/server/config' {=# setupFn.isDefined =} {=& setupFn.importStatement =} -import { ServerSetupFn, ServerSetupFnContext } from './types' +import { ServerSetupFn, ServerSetupFnContext } from 'wasp/server/types' {=/ setupFn.isDefined =} {=# isPgBossJobExecutorUsed =} diff --git a/waspc/data/Generator/templates/server/src/types/index.ts b/waspc/data/Generator/templates/server/src/types/index.ts index 205014216e..d18c167e2d 100644 --- a/waspc/data/Generator/templates/server/src/types/index.ts +++ b/waspc/data/Generator/templates/server/src/types/index.ts @@ -1,18 +1,5 @@ {{={= =}=}} -import { type Application } from 'express' -import { Server } from 'http' - -export type ServerSetupFn = (context: ServerSetupFnContext) => Promise - -export type ServerSetupFnContext = { - app: Application, - server: Server, -} - -export type { Application } from 'express' -export type { Server } from 'http' - {=# isEmailAuthEnabled =} export type { GetVerificationEmailContentFn, GetPasswordResetEmailContentFn } from '../auth/providers/email/types'; {=/ isEmailAuthEnabled =} diff --git a/waspc/examples/todo-typescript/.wasp/out/sdk/wasp/package.json b/waspc/examples/todo-typescript/.wasp/out/sdk/wasp/package.json index 290eff1d56..406ddaca18 100644 --- a/waspc/examples/todo-typescript/.wasp/out/sdk/wasp/package.json +++ b/waspc/examples/todo-typescript/.wasp/out/sdk/wasp/package.json @@ -46,6 +46,7 @@ "./universal/validators": "./dist/universal/validators.js", "./server/dbClient": "./dist/server/dbClient.js", "./server/config": "./dist/server/config.js", + "./server/types": "./dist/server/types/index.js", "./server/utils": "./dist/server/utils.js", "./server/actions": "./dist/server/actions/index.js", "./server/queries": "./dist/server/queries/index.js", diff --git a/waspc/examples/todo-typescript/main.wasp b/waspc/examples/todo-typescript/main.wasp index 80cb6d9354..c3612af64b 100644 --- a/waspc/examples/todo-typescript/main.wasp +++ b/waspc/examples/todo-typescript/main.wasp @@ -41,6 +41,7 @@ app TodoTypescript { system: PostgreSQL }, server: { + setupFn: import { serverSetup } from "@src/serverSetup.js", middlewareConfigFn: import { serverMiddlewareFn } from "@src/serverSetup.js" } } diff --git a/waspc/examples/todo-typescript/src/serverSetup.ts b/waspc/examples/todo-typescript/src/serverSetup.ts index 968dfe8514..56cf331dfd 100644 --- a/waspc/examples/todo-typescript/src/serverSetup.ts +++ b/waspc/examples/todo-typescript/src/serverSetup.ts @@ -2,6 +2,7 @@ import express from 'express' import cors from 'cors' import type { MiddlewareConfigFn } from 'wasp/server/middleware' import config from 'wasp/server/config' +import type { Application, ServerSetupFn } from 'wasp/server/types' export const serverMiddlewareFn: MiddlewareConfigFn = (middlewareConfig) => { // Example of adding an extra domains to CORS. @@ -21,3 +22,10 @@ export const fooBarNamespace: MiddlewareConfigFn = (middlewareConfig) => { return middlewareConfig } + +export const serverSetup: ServerSetupFn = async ({ app }: { app: Application}) => { + app.get('/customRoute', (_req, res) => { + res.send('I am a custom route') + }) + console.log("I am a server setup function!"); +} diff --git a/waspc/src/Wasp/Generator/SdkGenerator.hs b/waspc/src/Wasp/Generator/SdkGenerator.hs index 60109edb50..9d5f230da5 100644 --- a/waspc/src/Wasp/Generator/SdkGenerator.hs +++ b/waspc/src/Wasp/Generator/SdkGenerator.hs @@ -94,6 +94,7 @@ genSdkReal spec = <++> genEntitiesAndServerTypesDirs spec <++> genApis spec <++> genMiddleware spec + <++> genExportedTypesDir spec where genFileCopy = return . C.mkTmplFd @@ -288,6 +289,10 @@ genServerUtils spec = return $ C.mkTmplFdWithData [relfile|server/utils.ts|] tmp where tmplData = object ["isAuthEnabled" .= (isAuthEnabled spec :: Bool)] +genExportedTypesDir :: AppSpec -> Generator [FileDraft] +genExportedTypesDir _spec = + return [C.mkTmplFd [relfile|server/types/index.ts|]] + genMiddleware :: AppSpec -> Generator [FileDraft] genMiddleware _spec = sequence diff --git a/waspc/src/Wasp/Generator/ServerGenerator.hs b/waspc/src/Wasp/Generator/ServerGenerator.hs index 27173f67a3..dc0d2b7994 100644 --- a/waspc/src/Wasp/Generator/ServerGenerator.hs +++ b/waspc/src/Wasp/Generator/ServerGenerator.hs @@ -323,10 +323,8 @@ genExportedTypesDir spec = where tmplData = object - [ "isExternalAuthEnabled" .= isExternalAuthEnabled, - "isEmailAuthEnabled" .= isEmailAuthEnabled + [ "isEmailAuthEnabled" .= isEmailAuthEnabled ] - isExternalAuthEnabled = AS.App.Auth.isExternalAuthEnabled <$> maybeAuth isEmailAuthEnabled = AS.App.Auth.isEmailAuthEnabled <$> maybeAuth maybeAuth = AS.App.auth $ snd $ getApp spec