My Next. js Приложение развернуто на Firebase. Я использую собственный сервер (server.ts) для запуска приложения (узел src / server.ts). Следующий код - server.ts и firebaseFunctions. js. server.ts работает локально, поэтому прокси работает. Почему не работает на fierbase? Подскажите пожалуйста решение.
// @ts-ignore
const express = require("express");
const next = require("next");
const { createProxyMiddleware } = require("http-proxy-middleware");
const port = parseInt(process.env.PORT, 10) || 3000;
const dev = process.env.NODE_ENV !== "production";
const API_URL = process.env.API_URL;
const app = next({ dev });
const handle = app.getRequestHandler();
app.prepare().then(() => {
const server = express();
console.log("sercer")
server.use(
"/api",
createProxyMiddleware({
target: "https://tus-schedule-api.herokuapp.com",
changeOrigin: true,
})
);
server.get("/super_test", (req, res) => {
return res.status(200).send();
});
server.all("*", (req, res) => {
return handle(req, res);
});
server.listen(port, (err) => {
if (err) throw err;
console.log(`> Ready on http://localhost:${port}`);
});
});
const { join } = require("path");
const { https } = require("firebase-functions");
const { default: next } = require("next");
const isDev = process.env.NODE_ENV !== "production";
const nextjsDistDir = join("src", require("./src/next.config.js").distDir);
const nextjsServer = next({
dev: isDev,
conf: {
distDir: nextjsDistDir,
},
});
const nextjsHandle = nextjsServer.getRequestHandler();
exports.nextjsFunc = https.onRequest((req, res) => {
return nextjsServer.prepare().then(() => nextjsHandle(req, res));
});