Add receive bandwidth
This commit is contained in:
parent
ef69bf9256
commit
a57d32d05d
4 changed files with 77 additions and 6 deletions
|
@ -30,12 +30,13 @@ export const receiveBandwidth = async (
|
||||||
const { publicKey, bytesIn, bytesOut } = peer;
|
const { publicKey, bytesIn, bytesOut } = peer;
|
||||||
|
|
||||||
// Find the site by public key
|
// Find the site by public key
|
||||||
const site = await trx.query.sites.findFirst({
|
const [site] = await trx
|
||||||
where: eq(sites.pubKey, publicKey)
|
.select()
|
||||||
});
|
.from(sites)
|
||||||
|
.where(eq(sites.pubKey, publicKey))
|
||||||
|
.limit(1);
|
||||||
|
|
||||||
if (!site) {
|
if (!site) {
|
||||||
logger.warn(`Site not found for public key: ${publicKey}`);
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
let online = site.online;
|
let online = site.online;
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
import { handleNewtRegisterMessage } from "./newt";
|
import { handleNewtRegisterMessage, handleReceiveBandwidthMessage } from "./newt";
|
||||||
import { handleOlmRegisterMessage } from "./olm";
|
import { handleOlmRegisterMessage } from "./olm";
|
||||||
import { handleGetConfigMessage } from "./newt/handleGetConfigMessage";
|
import { handleGetConfigMessage } from "./newt/handleGetConfigMessage";
|
||||||
import { MessageHandler } from "./ws";
|
import { MessageHandler } from "./ws";
|
||||||
|
@ -7,4 +7,5 @@ export const messageHandlers: Record<string, MessageHandler> = {
|
||||||
"newt/wg/register": handleNewtRegisterMessage,
|
"newt/wg/register": handleNewtRegisterMessage,
|
||||||
"olm/wg/register": handleOlmRegisterMessage,
|
"olm/wg/register": handleOlmRegisterMessage,
|
||||||
"newt/wg/get-config": handleGetConfigMessage,
|
"newt/wg/get-config": handleGetConfigMessage,
|
||||||
|
"newt/receive-bandwidth": handleReceiveBandwidthMessage
|
||||||
};
|
};
|
||||||
|
|
68
server/routers/newt/handleReceiveBandwidthMessage.ts
Normal file
68
server/routers/newt/handleReceiveBandwidthMessage.ts
Normal file
|
@ -0,0 +1,68 @@
|
||||||
|
import db from "@server/db";
|
||||||
|
import { MessageHandler } from "../ws";
|
||||||
|
import { clients, Newt } from "@server/db/schema";
|
||||||
|
import { eq } from "drizzle-orm";
|
||||||
|
import logger from "@server/logger";
|
||||||
|
|
||||||
|
interface PeerBandwidth {
|
||||||
|
publicKey: string;
|
||||||
|
bytesIn: number;
|
||||||
|
bytesOut: number;
|
||||||
|
}
|
||||||
|
|
||||||
|
export const handleReceiveBandwidthMessage: MessageHandler = async (context) => {
|
||||||
|
const { message, client, sendToClient } = context;
|
||||||
|
const newt = client as Newt;
|
||||||
|
|
||||||
|
const bandwidthData: PeerBandwidth[] = message.data;
|
||||||
|
|
||||||
|
if (!Array.isArray(bandwidthData)) {
|
||||||
|
throw new Error("Invalid bandwidth data");
|
||||||
|
}
|
||||||
|
|
||||||
|
await db.transaction(async (trx) => {
|
||||||
|
for (const peer of bandwidthData) {
|
||||||
|
const { publicKey, bytesIn, bytesOut } = peer;
|
||||||
|
|
||||||
|
// Find the site by public key
|
||||||
|
const [client] = await trx
|
||||||
|
.select()
|
||||||
|
.from(clients)
|
||||||
|
.where(eq(clients.pubKey, publicKey))
|
||||||
|
.limit(1);
|
||||||
|
|
||||||
|
if (!client) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
let online = client.online;
|
||||||
|
|
||||||
|
// if the bandwidth for the site is > 0 then set it to online. if it has been less than 0 (no update) for 5 minutes then set it to offline
|
||||||
|
if (bytesIn > 0 || bytesOut > 0) {
|
||||||
|
online = true;
|
||||||
|
} else if (client.lastBandwidthUpdate) {
|
||||||
|
const lastBandwidthUpdate = new Date(
|
||||||
|
client.lastBandwidthUpdate
|
||||||
|
);
|
||||||
|
const currentTime = new Date();
|
||||||
|
const diff =
|
||||||
|
currentTime.getTime() - lastBandwidthUpdate.getTime();
|
||||||
|
if (diff < 300000) {
|
||||||
|
online = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Update the site's bandwidth usage
|
||||||
|
await trx
|
||||||
|
.update(clients)
|
||||||
|
.set({
|
||||||
|
megabytesOut: (client.megabytesIn || 0) + bytesIn,
|
||||||
|
megabytesIn: (client.megabytesOut || 0) + bytesOut,
|
||||||
|
lastBandwidthUpdate: new Date().toISOString(),
|
||||||
|
online
|
||||||
|
})
|
||||||
|
.where(eq(clients.clientId, client.clientId));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
logger.info("Handling register olm message!");
|
||||||
|
};
|
|
@ -1,3 +1,4 @@
|
||||||
export * from "./createNewt";
|
export * from "./createNewt";
|
||||||
export * from "./getToken";
|
export * from "./getToken";
|
||||||
export * from "./handleRegisterMessage";
|
export * from "./handleNewtRegisterMessage";
|
||||||
|
export* from "./handleReceiveBandwidthMessage";
|
Loading…
Add table
Reference in a new issue