feat(ocme): manual camera trigger for the wrapper added
This commit is contained in:
49
server/services/ocme/controller/triggerCamera.ts
Normal file
49
server/services/ocme/controller/triggerCamera.ts
Normal file
@@ -0,0 +1,49 @@
|
||||
import net from "net";
|
||||
import { db } from "../../../../database/dbclient.js";
|
||||
import { settings } from "../../../../database/schema/settings.js";
|
||||
import { eq } from "drizzle-orm";
|
||||
import { createLog } from "../../logger/logger.js";
|
||||
|
||||
export const triggerScanner = async () => {
|
||||
const camera = new net.Socket();
|
||||
let setting = await db
|
||||
.select()
|
||||
.from(settings)
|
||||
.where(eq(settings.name, "zebraScanners"));
|
||||
if (setting.length === 0) {
|
||||
return {
|
||||
success: false,
|
||||
message: "Looks like the setting is missing.",
|
||||
};
|
||||
}
|
||||
const scannerData = JSON.parse(setting[0]?.value);
|
||||
let data = scannerData.filter((n: any) => n.name === "wrapper1");
|
||||
let port = data[0].port;
|
||||
console.log(data);
|
||||
createLog(
|
||||
"info",
|
||||
"wrapperScanner",
|
||||
"ocme",
|
||||
`End of line Camera was triggered`
|
||||
);
|
||||
return new Promise((resolve, reject) => {
|
||||
camera.connect(port, data[0].ip, async () => {
|
||||
createLog("info", "wrapperScanner", "ocme", `Triggered`);
|
||||
camera.write("TRIGGER", "utf8");
|
||||
camera.end();
|
||||
resolve({ success: true, message: "Camera was triggered." });
|
||||
});
|
||||
|
||||
camera.on("error", (error) => {
|
||||
createLog("error", "wrapperScanner", "ocme", `${error}`);
|
||||
resolve({
|
||||
success: false,
|
||||
message: `There was an error triggering the camera: ${JSON.stringify(
|
||||
error
|
||||
)}`,
|
||||
});
|
||||
});
|
||||
|
||||
resolve({ success: true, message: "Camera was triggered." });
|
||||
});
|
||||
};
|
||||
25
server/services/ocme/route/triggerCamera.ts
Normal file
25
server/services/ocme/route/triggerCamera.ts
Normal file
@@ -0,0 +1,25 @@
|
||||
import { createRoute, OpenAPIHono, z } from "@hono/zod-openapi";
|
||||
import { getInfo } from "../controller/getInfo.js";
|
||||
import { apiHit } from "../../../globalUtils/apiHits.js";
|
||||
import { responses } from "../../../globalUtils/routeDefs/responses.js";
|
||||
import { triggerScanner } from "../controller/triggerCamera.js";
|
||||
|
||||
const app = new OpenAPIHono({ strict: false });
|
||||
|
||||
app.openapi(
|
||||
createRoute({
|
||||
tags: ["ocme"],
|
||||
summary: "Triggers the camera at the end of the dyco.",
|
||||
method: "get",
|
||||
path: "/manualCameraTrigger",
|
||||
responses: responses(),
|
||||
}),
|
||||
async (c) => {
|
||||
// make sure we have a vaid user being accessed thats really logged in
|
||||
apiHit(c, { endpoint: "api/auth/register" });
|
||||
const manualTrigger = await triggerScanner();
|
||||
console.log(manualTrigger);
|
||||
return c.json({ success: true, message: "Manual triggered" });
|
||||
}
|
||||
);
|
||||
export default app;
|
||||
@@ -1,23 +1,28 @@
|
||||
import net from "net";
|
||||
import {OpenAPIHono} from "@hono/zod-openapi";
|
||||
import {createLog} from "../logger/logger.js";
|
||||
import { OpenAPIHono } from "@hono/zod-openapi";
|
||||
import { createLog } from "../logger/logger.js";
|
||||
|
||||
import startTCP from "./route/startServer.js";
|
||||
import stopTCP from "./route/stopServer.js";
|
||||
import restartTCP from "./route/restartServer.js";
|
||||
import {db} from "../../../database/dbclient.js";
|
||||
import {settings} from "../../../database/schema/settings.js";
|
||||
import {eq} from "drizzle-orm";
|
||||
import { db } from "../../../database/dbclient.js";
|
||||
import { settings } from "../../../database/schema/settings.js";
|
||||
import { eq } from "drizzle-orm";
|
||||
import { postLabelData } from "../ocme/controller/postRunningNr.js";
|
||||
|
||||
let tcpServer: net.Server;
|
||||
let tcpSockets: Set<net.Socket> = new Set();
|
||||
let isServerRunning = false;
|
||||
|
||||
const tcpPort = await db.select().from(settings).where(eq(settings.name, "tcpPort"));
|
||||
const tcpPort = await db
|
||||
.select()
|
||||
.from(settings)
|
||||
.where(eq(settings.name, "tcpPort"));
|
||||
const app = new OpenAPIHono();
|
||||
|
||||
export const startTCPServer = () => {
|
||||
if (isServerRunning) return {success: false, message: "Server is already running"};
|
||||
if (isServerRunning)
|
||||
return { success: false, message: "Server is already running" };
|
||||
|
||||
tcpServer = net.createServer((socket) => {
|
||||
console.log("Client connected");
|
||||
@@ -25,7 +30,19 @@ export const startTCPServer = () => {
|
||||
tcpSockets.add(socket);
|
||||
socket.on("data", (data: Buffer) => {
|
||||
console.log("Received:", data.toString());
|
||||
socket.write("Message received");
|
||||
const parseData = data.toString("utf-8").trimEnd().split(" ");
|
||||
// hb from the scanners
|
||||
if (parseData[0] === "HB") {
|
||||
return;
|
||||
}
|
||||
|
||||
// alert from the printers
|
||||
if (parseData[0] === "ALERT:" || parseData[0] === "ALERT") {
|
||||
return;
|
||||
}
|
||||
|
||||
// from the wrapper send the data
|
||||
postLabelData(parseData);
|
||||
});
|
||||
|
||||
socket.on("end", () => {
|
||||
@@ -40,16 +57,22 @@ export const startTCPServer = () => {
|
||||
});
|
||||
|
||||
tcpServer.listen(tcpPort[0]?.value ?? 2222, () => {
|
||||
createLog("info", "lst", "tcp", `TCP Server listening on port ${tcpPort[0]?.value ?? 2222}`);
|
||||
createLog(
|
||||
"info",
|
||||
"lst",
|
||||
"tcp",
|
||||
`TCP Server listening on port ${tcpPort[0]?.value ?? 2222}`
|
||||
);
|
||||
});
|
||||
|
||||
isServerRunning = true;
|
||||
return {success: true, message: "TCP Server started"};
|
||||
return { success: true, message: "TCP Server started" };
|
||||
};
|
||||
|
||||
// Function to stop the TCP server
|
||||
export const stopTCPServer = () => {
|
||||
if (!isServerRunning) return {success: false, message: "Server is not running"};
|
||||
if (!isServerRunning)
|
||||
return { success: false, message: "Server is not running" };
|
||||
for (const socket of tcpSockets) {
|
||||
socket.destroy();
|
||||
}
|
||||
@@ -58,7 +81,7 @@ export const stopTCPServer = () => {
|
||||
console.log("TCP Server stopped");
|
||||
});
|
||||
isServerRunning = false;
|
||||
return {success: true, message: "TCP Server stopped"};
|
||||
return { success: true, message: "TCP Server stopped" };
|
||||
};
|
||||
|
||||
app.route("/tcpserver/start", startTCP);
|
||||
|
||||
Reference in New Issue
Block a user