Server work
This commit is contained in:
@@ -0,0 +1,14 @@
|
|||||||
|
import { BunContext, BunHttpServer, BunRuntime } from "@effect/platform-bun"
|
||||||
|
import { Effect, Layer } from "effect"
|
||||||
|
import { ServerConfig } from "./config"
|
||||||
|
import { Server } from "./server"
|
||||||
|
|
||||||
|
|
||||||
|
Layer.launch(Server).pipe(
|
||||||
|
Effect.provide(ServerConfig.httpPort.pipe(
|
||||||
|
Effect.map(port => BunHttpServer.layer({ port })),
|
||||||
|
Layer.unwrapEffect,
|
||||||
|
)),
|
||||||
|
Effect.provide(BunContext.layer),
|
||||||
|
BunRuntime.runMain,
|
||||||
|
)
|
||||||
|
|||||||
@@ -1,16 +1,27 @@
|
|||||||
import { HttpMiddleware, HttpRouter, HttpServer } from "@effect/platform"
|
import { HttpMiddleware, HttpRouter, HttpServer, HttpServerResponse, Path } from "@effect/platform"
|
||||||
import { Effect, flow, Layer } from "effect"
|
import { Effect, flow, Layer } from "effect"
|
||||||
import { ServerConfig } from "./config"
|
|
||||||
|
|
||||||
|
|
||||||
const router = HttpRouter.empty
|
const router = HttpRouter.empty.pipe(
|
||||||
|
)
|
||||||
|
|
||||||
export const HttpAppLive = ServerConfig.mode.pipe(
|
export const HttpAppDevelopment = router.pipe(
|
||||||
Effect.map(mode => HttpRouter.empty.pipe(
|
HttpServer.serve(flow(
|
||||||
HttpServer.serve(flow(
|
HttpMiddleware.logger,
|
||||||
HttpMiddleware.logger,
|
HttpMiddleware.xForwardedHeaders,
|
||||||
HttpMiddleware.xForwardedHeaders,
|
)),
|
||||||
)),
|
HttpServer.withLogAddress,
|
||||||
|
)
|
||||||
|
|
||||||
|
export const HttpAppProduction = Effect.all([
|
||||||
|
Path.Path,
|
||||||
|
Effect.succeed(import.meta.resolve("@website/webapp")),
|
||||||
|
]).pipe(
|
||||||
|
Effect.map(([path, webappDist]) => router.pipe(
|
||||||
|
HttpRouter.all("/", HttpServerResponse.file(path.join(webappDist, "index.html"))),
|
||||||
|
HttpRouter.all("/assets", HttpServerResponse.file(path.join(webappDist, "assets"))),
|
||||||
|
|
||||||
|
HttpServer.serve(HttpMiddleware.xForwardedHeaders),
|
||||||
HttpServer.withLogAddress,
|
HttpServer.withLogAddress,
|
||||||
)),
|
)),
|
||||||
|
|
||||||
|
|||||||
@@ -1,14 +1,14 @@
|
|||||||
import { Effect, flow, Layer, Match } from "effect"
|
import { Effect, flow, Layer, Logger, Match } from "effect"
|
||||||
import { ServerConfig } from "./config"
|
import { ServerConfig } from "./config"
|
||||||
import { HttpAppLive } from "./http"
|
import { HttpAppDevelopment, HttpAppProduction } from "./http"
|
||||||
|
|
||||||
|
|
||||||
const ServerDevelopment = Layer.empty.pipe(
|
const ServerDevelopment = Layer.empty.pipe(
|
||||||
Layer.provideMerge(HttpAppLive),
|
Layer.provideMerge(HttpAppDevelopment),
|
||||||
)
|
)
|
||||||
|
|
||||||
const ServerProduction = Layer.empty.pipe(
|
const ServerProduction = Layer.empty.pipe(
|
||||||
Layer.provideMerge(HttpAppLive),
|
Layer.provideMerge(HttpAppProduction),
|
||||||
)
|
)
|
||||||
|
|
||||||
export const Server = ServerConfig.mode.pipe(
|
export const Server = ServerConfig.mode.pipe(
|
||||||
@@ -20,4 +20,5 @@ export const Server = ServerConfig.mode.pipe(
|
|||||||
)),
|
)),
|
||||||
|
|
||||||
Layer.unwrapEffect,
|
Layer.unwrapEffect,
|
||||||
|
Layer.provideMerge(Logger.pretty),
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
"name": "@website/webapp",
|
"name": "@website/webapp",
|
||||||
"private": true,
|
"private": true,
|
||||||
"type": "module",
|
"type": "module",
|
||||||
|
"module": "./dist",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"dev": "vite",
|
"dev": "vite",
|
||||||
"build": "tsc -b && vite build",
|
"build": "tsc -b && vite build",
|
||||||
|
|||||||
Reference in New Issue
Block a user