improve backend logic

This commit is contained in:
Ishaan Dey
2024-04-21 22:55:49 -04:00
parent e7ca2d0124
commit 14d95eb8fe
12 changed files with 296 additions and 31 deletions

View File

@ -16,6 +16,7 @@ const express_1 = __importDefault(require("express"));
const dotenv_1 = __importDefault(require("dotenv"));
const http_1 = require("http");
const socket_io_1 = require("socket.io");
const zod_1 = require("zod");
dotenv_1.default.config();
const app = (0, express_1.default)();
const port = process.env.PORT || 4000;
@ -26,24 +27,54 @@ const io = new socket_io_1.Server(httpServer, {
origin: "*",
},
});
const handshakeSchema = zod_1.z.object({
userId: zod_1.z.string(),
sandboxId: zod_1.z.string(),
type: zod_1.z.enum(["node", "react"]),
EIO: zod_1.z.string(),
transport: zod_1.z.string(),
});
io.use((socket, next) => __awaiter(void 0, void 0, void 0, function* () {
const q = socket.handshake.query;
console.log("middleware");
console.log(q);
if (!q.userId || !q.sandboxId) {
const parseQuery = handshakeSchema.safeParse(q);
if (!parseQuery.success) {
console.log("Invalid request.");
next(new Error("Invalid request."));
return;
}
const dbUser = yield fetch(`http://localhost:8787/api/user?id=${q.userId}`);
const dbUserJSON = yield dbUser.json();
if (!dbUserJSON || !dbUserJSON.sandbox.includes(q.sandboxId)) {
const query = parseQuery.data;
const dbUser = yield fetch(`http://localhost:8787/api/user?id=${query.userId}`);
const dbUserJSON = (yield dbUser.json());
console.log("dbUserJSON:", dbUserJSON);
if (!dbUserJSON) {
console.log("DB error.");
next(new Error("DB error."));
return;
}
const sandbox = dbUserJSON.sandbox.find((s) => s.id === query.sandboxId);
if (!sandbox) {
console.log("Invalid credentials.");
next(new Error("Invalid credentials."));
return;
}
const data = {
userId: query.userId,
sandboxId: query.sandboxId,
type: query.type,
init: sandbox.init,
};
socket.data = data;
next();
}));
io.on("connection", (socket) => __awaiter(void 0, void 0, void 0, function* () {
console.log(`connection`);
const userId = socket.handshake.query.userId;
console.log(userId);
const data = socket.data;
console.log("init:", data.init);
if (!data.init) {
// const dbUser = await fetch(
// `http://localhost:8787/sandbox/${data.sandboxId}/init`
// )
}
// socket.emit("loaded", {
// rootContent: await fetchDir("/workspace", "")
// });

3
backend/server/dist/types.js vendored Normal file
View File

@ -0,0 +1,3 @@
"use strict";
// DB Types
Object.defineProperty(exports, "__esModule", { value: true });

View File

@ -4,6 +4,7 @@ import { createServer } from "http"
import { Server } from "socket.io"
import { z } from "zod"
import { User } from "./types"
dotenv.config()
@ -17,31 +18,77 @@ const io = new Server(httpServer, {
},
})
const handshakeSchema = z.object({
userId: z.string(),
sandboxId: z.string(),
type: z.enum(["node", "react"]),
EIO: z.string(),
transport: z.string(),
})
io.use(async (socket, next) => {
const q = socket.handshake.query
console.log("middleware")
console.log(q)
if (!q.userId || !q.sandboxId) {
const parseQuery = handshakeSchema.safeParse(q)
if (!parseQuery.success) {
console.log("Invalid request.")
next(new Error("Invalid request."))
return
}
const dbUser = await fetch(`http://localhost:8787/api/user?id=${q.userId}`)
const dbUserJSON = await dbUser.json()
const query = parseQuery.data
if (!dbUserJSON || !dbUserJSON.sandbox.includes(q.sandboxId)) {
const dbUser = await fetch(
`http://localhost:8787/api/user?id=${query.userId}`
)
const dbUserJSON = (await dbUser.json()) as User
console.log("dbUserJSON:", dbUserJSON)
if (!dbUserJSON) {
console.log("DB error.")
next(new Error("DB error."))
return
}
const sandbox = dbUserJSON.sandbox.find((s) => s.id === query.sandboxId)
if (!sandbox) {
console.log("Invalid credentials.")
next(new Error("Invalid credentials."))
return
}
const data = {
userId: query.userId,
sandboxId: query.sandboxId,
type: query.type,
init: sandbox.init,
}
socket.data = data
next()
})
io.on("connection", async (socket) => {
console.log(`connection`)
const userId = socket.handshake.query.userId
const data = socket.data as {
userId: string
sandboxId: string
type: "node" | "react"
init: boolean
}
console.log(userId)
console.log("init:", data.init)
if (!data.init) {
// const dbUser = await fetch(
// `http://localhost:8787/sandbox/${data.sandboxId}/init`
// )
}
// socket.emit("loaded", {
// rootContent: await fetchDir("/workspace", "")

View File

@ -0,0 +1,17 @@
// DB Types
export type User = {
id: string
name: string
email: string
sandbox: Sandbox[]
}
export type Sandbox = {
id: string
name: string
type: "react" | "node"
init: boolean
bucket: string | null
userId: string
}