server.ts 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. import env from "./env";
  2. import asyncHandler from "express-async-handler";
  3. import cookieParser from "cookie-parser";
  4. import passport from "passport";
  5. import express from "express";
  6. import helmet from "helmet";
  7. import morgan from "morgan";
  8. import nextApp from "next";
  9. import * as Sentry from "@sentry/node";
  10. import * as helpers from "./handlers/helpers";
  11. import * as links from "./handlers/links";
  12. import * as auth from "./handlers/auth";
  13. import __v1Routes from "./__v1";
  14. import routes from "./routes";
  15. import "./cron";
  16. import "./passport";
  17. const port = env.PORT;
  18. const app = nextApp({ dir: "./client", dev: env.isDev });
  19. const handle = app.getRequestHandler();
  20. app.prepare().then(async () => {
  21. const server = express();
  22. server.set("trust proxy", true);
  23. if (env.isDev) {
  24. server.use(morgan("dev"));
  25. } else if (env.SENTRY_PRIVATE_DSN) {
  26. Sentry.init({
  27. dsn: env.SENTRY_PRIVATE_DSN,
  28. environment: process.env.NODE_ENV
  29. });
  30. server.use(
  31. Sentry.Handlers.requestHandler({
  32. ip: true,
  33. user: ["id", "email"]
  34. })
  35. );
  36. }
  37. server.use(helmet());
  38. server.use(cookieParser());
  39. server.use(express.json());
  40. server.use(express.urlencoded({ extended: true }));
  41. server.use(passport.initialize());
  42. server.use(express.static("static"));
  43. server.use(helpers.ip);
  44. server.use(asyncHandler(links.redirectCustomDomain));
  45. server.use("/api/v2", routes);
  46. server.use("/api", __v1Routes);
  47. server.get(
  48. "/reset-password/:resetPasswordToken?",
  49. asyncHandler(auth.resetPassword),
  50. (req, res) => app.render(req, res, "/reset-password", { token: req.token })
  51. );
  52. server.get(
  53. "/verify/:verificationToken?",
  54. asyncHandler(auth.verify),
  55. (req, res) => app.render(req, res, "/verify", { token: req.token })
  56. );
  57. server.get("/:id", asyncHandler(links.redirect(app)));
  58. // Error handler
  59. server.use(helpers.error);
  60. // Handler everything else by Next.js
  61. server.get("*", (req, res) => handle(req, res));
  62. server.listen(port, err => {
  63. if (err) throw err;
  64. console.log(`> Ready on http://localhost:${port}`);
  65. });
  66. });