feat(rfid): work on the readers and there functions

This commit is contained in:
2025-03-27 21:08:05 -05:00
parent f9f68ce969
commit b5de6445b3
9 changed files with 275 additions and 134 deletions

View File

@@ -2,10 +2,10 @@
* While in production we will monitor the readers if we have not gotten a heartbeat in the last 5 min we will send a reboot command along with an email.
*/
import {eq, sql} from "drizzle-orm";
import {db} from "../../../../database/dbclient.js";
import {rfidReaders} from "../../../../database/schema/rfidReaders.js";
import {createLog} from "../../logger/logger.js";
import { eq, sql } from "drizzle-orm";
import { db } from "../../../../database/dbclient.js";
import { rfidReaders } from "../../../../database/schema/rfidReaders.js";
import { createLog } from "../../logger/logger.js";
export const newHeartBeat = async (reader: string) => {
/**
@@ -14,14 +14,30 @@ export const newHeartBeat = async (reader: string) => {
try {
const heatBeat = await db
.update(rfidReaders)
.set({lastHeartBeat: sql`NOW()`})
.where(eq(rfidReaders.reader, reader));
createLog("info", "rfid", "rfid", `${reader} just updated its heatBeat.`);
return {success: true, message: `${reader} just updated its heatBeat.`};
.update(rfidReaders)
.set({ lastHeartBeat: sql`NOW()` })
.where(eq(rfidReaders.reader, reader));
createLog(
"debug",
"rfid",
"rfid",
`${reader} just updated its heatBeat.`
);
return {
success: true,
message: `${reader} just updated its heatBeat.`,
};
} catch (error) {
createLog("error", "rfid", "rfid", `${reader} encountered an error while updating the heatbeat, ${error}`);
return {success: false, message: `${reader} encountered an error while updating the heatbeat, ${error}`};
createLog(
"error",
"rfid",
"rfid",
`${reader} encountered an error while updating the heatbeat, ${error}`
);
return {
success: false,
message: `${reader} encountered an error while updating the heatbeat, ${error}`,
};
}
};
@@ -31,14 +47,30 @@ export const badRead = async (reader: string) => {
*/
try {
const badRead = await db
.update(rfidReaders)
.set({lastTrigger: sql`NOW()`, lastTriggerGood: false})
.where(eq(rfidReaders.reader, reader));
createLog("info", "rfid", "rfid", `${reader} just Triggered a bad read.`);
return {success: true, message: `${reader} just Triggered a bad read.`};
.update(rfidReaders)
.set({ lastTrigger: sql`NOW()`, lastTriggerGood: false })
.where(eq(rfidReaders.reader, reader));
createLog(
"info",
"rfid",
"rfid",
`${reader} just Triggered a bad read.`
);
return {
success: true,
message: `${reader} just Triggered a bad read.`,
};
} catch (error) {
createLog("error", "rfid", "rfid", `${reader} encountered an error while updating the heatbeat, ${error}`);
return {success: false, message: `${reader} encountered an error while updating the heatbeat, ${error}`};
createLog(
"error",
"rfid",
"rfid",
`${reader} encountered an error while updating the heatbeat, ${error}`
);
return {
success: false,
message: `${reader} encountered an error while updating the heatbeat, ${error}`,
};
}
};
@@ -48,13 +80,29 @@ export const goodRead = async (reader: string) => {
*/
try {
const goodRead = await db
.update(rfidReaders)
.set({lastTrigger: sql`NOW()`, lastTriggerGood: true})
.where(eq(rfidReaders.reader, reader));
createLog("info", "rfid", "rfid", `${reader} just Triggered a good read.`);
return {success: true, message: `${reader} just Triggered a good read.`};
.update(rfidReaders)
.set({ lastTrigger: sql`NOW()`, lastTriggerGood: true })
.where(eq(rfidReaders.reader, reader));
createLog(
"info",
"rfid",
"rfid",
`${reader} just Triggered a good read.`
);
return {
success: true,
message: `${reader} just Triggered a good read.`,
};
} catch (error) {
createLog("error", "rfid", "rfid", `${reader} encountered an error while updating the heatbeat, ${error}`);
return {success: false, message: `${reader} encountered an error while updating the heatbeat, ${error}`};
createLog(
"error",
"rfid",
"rfid",
`${reader} encountered an error while updating the heatbeat, ${error}`
);
return {
success: false,
message: `${reader} encountered an error while updating the heatbeat, ${error}`,
};
}
};