2023-06-08 22:13:48 +02:00
|
|
|
process.env.NODE_ENV === "development"
|
|
|
|
? require("dotenv").config({ path: `.env.${process.env.NODE_ENV}` })
|
|
|
|
: require("dotenv").config();
|
|
|
|
|
2023-06-08 06:31:35 +02:00
|
|
|
const express = require("express");
|
|
|
|
const bodyParser = require("body-parser");
|
2023-07-15 02:32:30 +02:00
|
|
|
const serveIndex = require("serve-index");
|
2023-06-08 06:31:35 +02:00
|
|
|
const cors = require("cors");
|
2023-06-13 20:26:11 +02:00
|
|
|
const path = require("path");
|
2023-06-08 06:31:35 +02:00
|
|
|
const { reqBody } = require("./utils/http");
|
|
|
|
const { systemEndpoints } = require("./endpoints/system");
|
|
|
|
const { workspaceEndpoints } = require("./endpoints/workspaces");
|
|
|
|
const { chatEndpoints } = require("./endpoints/chat");
|
|
|
|
const { getVectorDbClass } = require("./utils/helpers");
|
2023-07-25 19:37:04 +02:00
|
|
|
const { adminEndpoints } = require("./endpoints/admin");
|
|
|
|
const { inviteEndpoints } = require("./endpoints/invite");
|
2023-08-10 22:23:23 +02:00
|
|
|
const { utilEndpoints } = require("./endpoints/utils");
|
2023-08-15 02:42:17 +02:00
|
|
|
const { Telemetry } = require("./models/telemetry");
|
2023-08-24 04:15:07 +02:00
|
|
|
const { developerEndpoints } = require("./endpoints/api");
|
2023-09-28 23:00:03 +02:00
|
|
|
const setupTelemetry = require("./utils/telemetry");
|
2023-06-04 04:28:07 +02:00
|
|
|
const app = express();
|
2023-06-13 20:26:11 +02:00
|
|
|
const apiRouter = express.Router();
|
2023-08-17 02:46:45 +02:00
|
|
|
const FILE_LIMIT = "3GB";
|
2023-06-04 04:28:07 +02:00
|
|
|
|
|
|
|
app.use(cors({ origin: true }));
|
2023-08-17 02:46:45 +02:00
|
|
|
app.use(bodyParser.text({ limit: FILE_LIMIT }));
|
|
|
|
app.use(bodyParser.json({ limit: FILE_LIMIT }));
|
2023-06-08 06:31:35 +02:00
|
|
|
app.use(
|
|
|
|
bodyParser.urlencoded({
|
2023-08-17 02:46:45 +02:00
|
|
|
limit: FILE_LIMIT,
|
2023-06-08 06:31:35 +02:00
|
|
|
extended: true,
|
|
|
|
})
|
|
|
|
);
|
2023-06-04 04:28:07 +02:00
|
|
|
|
2023-07-25 19:37:04 +02:00
|
|
|
app.use("/api", apiRouter);
|
2023-06-13 20:26:11 +02:00
|
|
|
systemEndpoints(apiRouter);
|
|
|
|
workspaceEndpoints(apiRouter);
|
|
|
|
chatEndpoints(apiRouter);
|
2023-07-25 19:37:04 +02:00
|
|
|
adminEndpoints(apiRouter);
|
|
|
|
inviteEndpoints(apiRouter);
|
2023-08-10 22:23:23 +02:00
|
|
|
utilEndpoints(apiRouter);
|
2023-08-24 04:15:07 +02:00
|
|
|
developerEndpoints(app, apiRouter);
|
2023-06-04 04:28:07 +02:00
|
|
|
|
2023-06-13 20:26:11 +02:00
|
|
|
apiRouter.post("/v/:command", async (request, response) => {
|
2023-06-04 04:28:07 +02:00
|
|
|
try {
|
2023-06-08 22:13:48 +02:00
|
|
|
const VectorDb = getVectorDbClass();
|
|
|
|
const { command } = request.params;
|
|
|
|
if (!Object.getOwnPropertyNames(VectorDb).includes(command)) {
|
|
|
|
response.status(500).json({
|
|
|
|
message: "invalid interface command",
|
|
|
|
commands: Object.getOwnPropertyNames(VectorDb),
|
|
|
|
});
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
const body = reqBody(request);
|
|
|
|
const resBody = await VectorDb[command](body);
|
|
|
|
response.status(200).json({ ...resBody });
|
|
|
|
} catch (e) {
|
|
|
|
// console.error(e)
|
|
|
|
console.error(JSON.stringify(e));
|
|
|
|
response.status(500).json({ error: e.message });
|
|
|
|
}
|
|
|
|
return;
|
2023-06-04 04:28:07 +02:00
|
|
|
} catch (e) {
|
2023-06-08 22:13:48 +02:00
|
|
|
console.log(e.message, e);
|
|
|
|
response.sendStatus(500).end();
|
2023-06-04 04:28:07 +02:00
|
|
|
}
|
2023-06-08 06:31:35 +02:00
|
|
|
});
|
2023-06-04 04:28:07 +02:00
|
|
|
|
2023-06-13 20:26:11 +02:00
|
|
|
if (process.env.NODE_ENV !== "development") {
|
2023-06-14 22:35:55 +02:00
|
|
|
app.use(
|
|
|
|
express.static(path.resolve(__dirname, "public"), { extensions: ["js"] })
|
|
|
|
);
|
2023-06-13 20:26:11 +02:00
|
|
|
|
|
|
|
app.use("/", function (_, response) {
|
|
|
|
response.sendFile(path.join(__dirname, "public", "index.html"));
|
2023-06-14 22:35:55 +02:00
|
|
|
});
|
2023-11-14 00:22:24 +01:00
|
|
|
|
|
|
|
app.get("/robots.txt", function (_, response) {
|
|
|
|
response.type("text/plain");
|
|
|
|
response.send("User-agent: *\nDisallow: /").end();
|
|
|
|
});
|
2023-06-13 20:26:11 +02:00
|
|
|
}
|
|
|
|
|
2023-07-15 02:32:30 +02:00
|
|
|
app.use(
|
|
|
|
"/system/data-exports",
|
|
|
|
serveIndex(__dirname + "/storage/exports", { icons: true })
|
|
|
|
);
|
|
|
|
|
2023-06-08 06:31:35 +02:00
|
|
|
app.all("*", function (_, response) {
|
2023-06-04 04:28:07 +02:00
|
|
|
response.sendStatus(404);
|
|
|
|
});
|
|
|
|
|
2023-06-08 06:31:35 +02:00
|
|
|
app
|
2023-06-15 08:12:59 +02:00
|
|
|
.listen(process.env.SERVER_PORT || 3001, async () => {
|
2023-08-15 02:42:17 +02:00
|
|
|
await setupTelemetry();
|
2023-06-08 06:31:35 +02:00
|
|
|
console.log(
|
2023-12-14 22:52:11 +01:00
|
|
|
`Primary server listening on port ${process.env.SERVER_PORT || 3001}`
|
2023-06-08 06:31:35 +02:00
|
|
|
);
|
|
|
|
})
|
2023-06-04 04:28:07 +02:00
|
|
|
.on("error", function (err) {
|
|
|
|
process.once("SIGUSR2", function () {
|
2023-08-15 02:42:17 +02:00
|
|
|
Telemetry.flush();
|
2023-06-04 04:28:07 +02:00
|
|
|
process.kill(process.pid, "SIGUSR2");
|
|
|
|
});
|
|
|
|
process.on("SIGINT", function () {
|
2023-08-15 02:42:17 +02:00
|
|
|
Telemetry.flush();
|
2023-06-04 04:28:07 +02:00
|
|
|
process.kill(process.pid, "SIGINT");
|
|
|
|
});
|
2023-06-08 06:31:35 +02:00
|
|
|
});
|