server.ts 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. // @ts-ignore -- generated package
  2. import "src/utils/environment";
  3. import * as sapper from "@sapper/server"; // eslint-disable-line import/no-unresolved
  4. import compression from "compression";
  5. import express, { Express } from "express";
  6. import session from "cookie-session";
  7. // @ts-ignore -- doesn't package its own types until 1.0.0-next.6
  8. import sirv from "sirv";
  9. import { createConnection, getConnectionOptions } from "typeorm";
  10. import { DB_ENTITIES } from "@shared/db/entities";
  11. import { ENV } from "src/utils/environment";
  12. import { logger } from "./utils/logging";
  13. import { AppSession } from "./utils/session";
  14. const PORT = process.env.PORT; // eslint-disable-line prefer-destructuring
  15. // @ts-ignore -- creates a warning after `rollup-plugin-replace` (set up in `rollup.config.js`)
  16. // replaces `process.env.NODE_ENV` with `"production"` during `prod`
  17. const dev = process.env.NODE_ENV === "development";
  18. logger.info("Staring webserver to port %s", PORT);
  19. const key = process.env.WEB_COOKIE_KEY;
  20. if (!key) {
  21. logger.error("WEB_COOKIE_KEY is not set, cannot run!");
  22. process.exit();
  23. }
  24. const createSapperServer = async (): Promise<Express> => {
  25. await createConnection({
  26. ...await getConnectionOptions(),
  27. entities: DB_ENTITIES,
  28. });
  29. const app = express();
  30. app.use(express.json());
  31. app.use(
  32. session({
  33. secret: key,
  34. name: "session",
  35. secure: !dev,
  36. domain: ENV.WEB_DOMAIN,
  37. }),
  38. compression({ threshold: 0 }),
  39. sirv("static", { dev }),
  40. sapper.middleware({
  41. session: (req): AppSession => ({
  42. }),
  43. }),
  44. );
  45. app.set("trust proxy", true);
  46. return app;
  47. };
  48. createSapperServer().then((app) => {
  49. app.listen(PORT, (err?: any): void => { // eslint-disable-line
  50. if (err) logger.error("Error on webserver: %s", err);
  51. });
  52. });
  53. export { sapper };