refactor: separate connection manager logic
This commit is contained in:
parent
486791f53e
commit
8381455f4d
33
backend/server/src/OwnerConnectionManager.ts
Normal file
33
backend/server/src/OwnerConnectionManager.ts
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
class Counter {
|
||||||
|
private count: number = 0
|
||||||
|
|
||||||
|
increment() {
|
||||||
|
this.count++
|
||||||
|
}
|
||||||
|
|
||||||
|
decrement() {
|
||||||
|
this.count = Math.max(0, this.count - 1)
|
||||||
|
}
|
||||||
|
|
||||||
|
getValue(): number {
|
||||||
|
return this.count
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Owner Connection Management
|
||||||
|
export class OwnerConnectionManager {
|
||||||
|
private connections: Record<string, Counter> = {}
|
||||||
|
|
||||||
|
ownerConnected(sandboxId: string) {
|
||||||
|
this.connections[sandboxId] ??= new Counter()
|
||||||
|
this.connections[sandboxId].increment()
|
||||||
|
}
|
||||||
|
|
||||||
|
ownerDisconnected(sandboxId: string) {
|
||||||
|
this.connections[sandboxId]?.decrement()
|
||||||
|
}
|
||||||
|
|
||||||
|
ownerIsConnected(sandboxId: string): boolean {
|
||||||
|
return this.connections[sandboxId]?.getValue() > 0
|
||||||
|
}
|
||||||
|
}
|
@ -7,6 +7,7 @@ import { Server } from "socket.io"
|
|||||||
import { AIWorker } from "./AIWorker"
|
import { AIWorker } from "./AIWorker"
|
||||||
|
|
||||||
import { DokkuClient } from "./DokkuClient"
|
import { DokkuClient } from "./DokkuClient"
|
||||||
|
import { OwnerConnectionManager } from "./OwnerConnectionManager"
|
||||||
import { SandboxManager } from "./SandboxManager"
|
import { SandboxManager } from "./SandboxManager"
|
||||||
import { SecureGitClient } from "./SecureGitClient"
|
import { SecureGitClient } from "./SecureGitClient"
|
||||||
import { socketAuth } from "./socketAuth"; // Import the new socketAuth middleware
|
import { socketAuth } from "./socketAuth"; // Import the new socketAuth middleware
|
||||||
@ -29,13 +30,8 @@ process.on("unhandledRejection", (reason, promise) => {
|
|||||||
// Do not exit the process
|
// Do not exit the process
|
||||||
})
|
})
|
||||||
|
|
||||||
// Check if the sandbox owner is connected
|
|
||||||
function isOwnerConnected(sandboxId: string): boolean {
|
|
||||||
return (connections[sandboxId] ?? 0) > 0
|
|
||||||
}
|
|
||||||
|
|
||||||
// Initialize containers and managers
|
// Initialize containers and managers
|
||||||
const connections: Record<string, number> = {}
|
const connectionManager = new OwnerConnectionManager()
|
||||||
const sandboxManagers: Record<string, SandboxManager> = {}
|
const sandboxManagers: Record<string, SandboxManager> = {}
|
||||||
|
|
||||||
// Load environment variables
|
// Load environment variables
|
||||||
@ -103,9 +99,9 @@ io.on("connection", async (socket) => {
|
|||||||
|
|
||||||
// Handle connection based on user type (owner or not)
|
// Handle connection based on user type (owner or not)
|
||||||
if (data.isOwner) {
|
if (data.isOwner) {
|
||||||
connections[data.sandboxId] = (connections[data.sandboxId] ?? 0) + 1
|
connectionManager.ownerConnected(data.sandboxId)
|
||||||
} else {
|
} else {
|
||||||
if (!isOwnerConnected(data.sandboxId)) {
|
if (!connectionManager.ownerIsConnected(data.sandboxId)) {
|
||||||
socket.emit("disableAccess", "The sandbox owner is not connected.")
|
socket.emit("disableAccess", "The sandbox owner is not connected.")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
@ -123,8 +119,7 @@ io.on("connection", async (socket) => {
|
|||||||
Object.entries(sandboxManager.handlers()).forEach(([event, handler]) => {
|
Object.entries(sandboxManager.handlers()).forEach(([event, handler]) => {
|
||||||
socket.on(event, async (options: any, callback?: (response: any) => void) => {
|
socket.on(event, async (options: any, callback?: (response: any) => void) => {
|
||||||
try {
|
try {
|
||||||
const response = await handler(options)
|
callback?.(await handler(options));
|
||||||
callback?.(response);
|
|
||||||
} catch (e: any) {
|
} catch (e: any) {
|
||||||
handleErrors(`Error processing event "${event}":`, e, socket);
|
handleErrors(`Error processing event "${event}":`, e, socket);
|
||||||
}
|
}
|
||||||
@ -134,12 +129,12 @@ io.on("connection", async (socket) => {
|
|||||||
socket.on("disconnect", async () => {
|
socket.on("disconnect", async () => {
|
||||||
try {
|
try {
|
||||||
if (data.isOwner) {
|
if (data.isOwner) {
|
||||||
connections[data.sandboxId]--
|
connectionManager.ownerDisconnected(data.sandboxId)
|
||||||
}
|
}
|
||||||
|
|
||||||
await sandboxManager.disconnect()
|
await sandboxManager.disconnect()
|
||||||
|
|
||||||
if (data.isOwner && connections[data.sandboxId] <= 0) {
|
if (data.isOwner && !connectionManager.ownerIsConnected(data.sandboxId)) {
|
||||||
socket.broadcast.emit(
|
socket.broadcast.emit(
|
||||||
"disableAccess",
|
"disableAccess",
|
||||||
"The sandbox owner has disconnected."
|
"The sandbox owner has disconnected."
|
||||||
@ -162,4 +157,4 @@ io.on("connection", async (socket) => {
|
|||||||
// Start the server
|
// Start the server
|
||||||
httpServer.listen(port, () => {
|
httpServer.listen(port, () => {
|
||||||
console.log(`Server running on port ${port}`)
|
console.log(`Server running on port ${port}`)
|
||||||
})
|
})
|
Loading…
x
Reference in New Issue
Block a user