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,64 +1,87 @@
|
|||||||
import net from "net";
|
import net from "net";
|
||||||
import {OpenAPIHono} from "@hono/zod-openapi";
|
import { OpenAPIHono } from "@hono/zod-openapi";
|
||||||
import {createLog} from "../logger/logger.js";
|
import { createLog } from "../logger/logger.js";
|
||||||
|
|
||||||
import startTCP from "./route/startServer.js";
|
import startTCP from "./route/startServer.js";
|
||||||
import stopTCP from "./route/stopServer.js";
|
import stopTCP from "./route/stopServer.js";
|
||||||
import restartTCP from "./route/restartServer.js";
|
import restartTCP from "./route/restartServer.js";
|
||||||
import {db} from "../../../database/dbclient.js";
|
import { db } from "../../../database/dbclient.js";
|
||||||
import {settings} from "../../../database/schema/settings.js";
|
import { settings } from "../../../database/schema/settings.js";
|
||||||
import {eq} from "drizzle-orm";
|
import { eq } from "drizzle-orm";
|
||||||
|
import { postLabelData } from "../ocme/controller/postRunningNr.js";
|
||||||
|
|
||||||
let tcpServer: net.Server;
|
let tcpServer: net.Server;
|
||||||
let tcpSockets: Set<net.Socket> = new Set();
|
let tcpSockets: Set<net.Socket> = new Set();
|
||||||
let isServerRunning = false;
|
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();
|
const app = new OpenAPIHono();
|
||||||
|
|
||||||
export const startTCPServer = () => {
|
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) => {
|
tcpServer = net.createServer((socket) => {
|
||||||
console.log("Client connected");
|
console.log("Client connected");
|
||||||
|
|
||||||
tcpSockets.add(socket);
|
tcpSockets.add(socket);
|
||||||
socket.on("data", (data: Buffer) => {
|
socket.on("data", (data: Buffer) => {
|
||||||
console.log("Received:", data.toString());
|
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;
|
||||||
|
}
|
||||||
|
|
||||||
socket.on("end", () => {
|
// alert from the printers
|
||||||
console.log("Client disconnected");
|
if (parseData[0] === "ALERT:" || parseData[0] === "ALERT") {
|
||||||
tcpSockets.delete(socket);
|
return;
|
||||||
});
|
}
|
||||||
|
|
||||||
socket.on("error", (err: Error) => {
|
// from the wrapper send the data
|
||||||
console.error("Socket error:", err);
|
postLabelData(parseData);
|
||||||
tcpSockets.delete(socket);
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
|
||||||
tcpServer.listen(tcpPort[0]?.value ?? 2222, () => {
|
socket.on("end", () => {
|
||||||
createLog("info", "lst", "tcp", `TCP Server listening on port ${tcpPort[0]?.value ?? 2222}`);
|
console.log("Client disconnected");
|
||||||
|
tcpSockets.delete(socket);
|
||||||
});
|
});
|
||||||
|
|
||||||
isServerRunning = true;
|
socket.on("error", (err: Error) => {
|
||||||
return {success: true, message: "TCP Server started"};
|
console.error("Socket error:", err);
|
||||||
|
tcpSockets.delete(socket);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
tcpServer.listen(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" };
|
||||||
};
|
};
|
||||||
|
|
||||||
// Function to stop the TCP server
|
// Function to stop the TCP server
|
||||||
export const stopTCPServer = () => {
|
export const stopTCPServer = () => {
|
||||||
if (!isServerRunning) return {success: false, message: "Server is not running"};
|
if (!isServerRunning)
|
||||||
for (const socket of tcpSockets) {
|
return { success: false, message: "Server is not running" };
|
||||||
socket.destroy();
|
for (const socket of tcpSockets) {
|
||||||
}
|
socket.destroy();
|
||||||
tcpSockets.clear();
|
}
|
||||||
tcpServer.close(() => {
|
tcpSockets.clear();
|
||||||
console.log("TCP Server stopped");
|
tcpServer.close(() => {
|
||||||
});
|
console.log("TCP Server stopped");
|
||||||
isServerRunning = false;
|
});
|
||||||
return {success: true, message: "TCP Server stopped"};
|
isServerRunning = false;
|
||||||
|
return { success: true, message: "TCP Server stopped" };
|
||||||
};
|
};
|
||||||
|
|
||||||
app.route("/tcpserver/start", startTCP);
|
app.route("/tcpserver/start", startTCP);
|
||||||
@@ -67,7 +90,7 @@ app.route("/tcpserver/restart", restartTCP);
|
|||||||
|
|
||||||
// start the server after on system start up
|
// start the server after on system start up
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
startTCPServer();
|
startTCPServer();
|
||||||
}, 5000);
|
}, 5000);
|
||||||
|
|
||||||
export default app;
|
export default app;
|
||||||
|
|||||||
Reference in New Issue
Block a user