ashok 5 months ago
commit b117eb42c2

@ -2737,26 +2737,52 @@ exports.raiseATicket = async (req, reply) => {
const issuesToAdd = []; const issuesToAdd = [];
// ✅ Only raise a ticket if master is disconnected // ✅ Only raise a ticket if master is disconnected
// if (masterConnectedStatus === "disconnected") {
// const existingMasterTicket = await Support.findOne({
// "issues.hardwareId": connected_to,
// "issues.type": "GSM or LoRa Disconnected"
// });
// if (!existingMasterTicket) {
// const slaveHardwareIds = disconnectedSlaves.map(s => s.slaveHardwareId);
// const slaveNames = disconnectedSlaves.map(s => s.slaveName);
// issuesToAdd.push({
// type: "GSM or LoRa Disconnected",
// masterHardwareId: connected_to,
// hardwareId: connected_to, // Master hardwareId
// hardwareIds: slaveHardwareIds, // Slave tankHardwareIds
// slaveNames,
// message: `Master ${connected_to} is disconnected along with ${slaveHardwareIds.length} slave(s)`
// });
// }
// }
if (masterConnectedStatus === "disconnected") { if (masterConnectedStatus === "disconnected") {
const existingMasterTicket = await Support.findOne({ const existingMasterTicket = await Support.findOne({
"issues.hardwareId": connected_to, "issues.hardwareId": connected_to,
"issues.type": "GSM or LoRa Disconnected" "issues.type": "GSM or LoRa Disconnected"
}); });
if (!existingMasterTicket) { if (!existingMasterTicket) {
const slaveHardwareIds = disconnectedSlaves.map(s => s.slaveHardwareId); const slaveHardwareIds = disconnectedSlaves.map(s => s.slaveHardwareId);
const slaveNames = disconnectedSlaves.map(s => s.slaveName); const slaveNames = disconnectedSlaves.map(s => s.slaveName);
issuesToAdd.push({ // Check if disconnection is at least 15 minutes old
type: "GSM or LoRa Disconnected", if (diffInMinutes >= 15) {
masterHardwareId: connected_to, issuesToAdd.push({
hardwareId: connected_to, // Master hardwareId type: "GSM or LoRa Disconnected",
hardwareIds: slaveHardwareIds, // Slave tankHardwareIds masterHardwareId: connected_to,
slaveNames, hardwareId: connected_to,
message: `Master ${connected_to} is disconnected along with ${slaveHardwareIds.length} slave(s)` hardwareIds: slaveHardwareIds,
}); slaveNames,
message: `Master ${connected_to} is disconnected along with ${slaveHardwareIds.length} slave(s)`,
disconnectedAt: lastDataTime // optional: for future tracking
});
}
} }
} }
if (issuesToAdd.length > 0) { if (issuesToAdd.length > 0) {
const supportRecord = await Support.findOne({ supportId: "AWHYSU64" }); const supportRecord = await Support.findOne({ supportId: "AWHYSU64" });

@ -2592,23 +2592,33 @@ exports.getOrdersByInstallationId = async (req, reply) => {
}); });
} }
// Fetch customer details & allocated sensors for each order const uniqueCustomersMap = new Map();
// Build unique customerId-based map
for (const order of orders) {
if (!uniqueCustomersMap.has(order.customerId)) {
uniqueCustomersMap.set(order.customerId, order);
}
}
// Only keep one order per customerId
const uniqueOrders = Array.from(uniqueCustomersMap.values());
// Enrich with customer and sensor info
const ordersWithDetails = await Promise.all( const ordersWithDetails = await Promise.all(
orders.map(async (order) => { uniqueOrders.map(async (order) => {
// Fetch customer details
const customer = await User.findOne({ customerId: order.customerId }).lean(); const customer = await User.findOne({ customerId: order.customerId }).lean();
// Fetch allocated sensors for this customer
const allocatedSensors = await Insensors.find({ const allocatedSensors = await Insensors.find({
storeId: order.storeId, storeId: order.storeId,
customerId: order.customerId, // Match only sensors allocated to this customer customerId: order.customerId,
status: "blocked", // Only fetch sensors that are allocated (blocked) status: "blocked",
}).lean(); }).lean();
return { return {
...order.toObject(), ...order.toObject(),
customer: customer || null, // Include customer details or null if not found customer: customer || null,
allocated_sensors: allocatedSensors, // List of allocated sensors allocated_sensors: allocatedSensors,
}; };
}) })
); );
@ -2618,6 +2628,7 @@ exports.getOrdersByInstallationId = async (req, reply) => {
message: "Orders fetched successfully", message: "Orders fetched successfully",
data: ordersWithDetails, data: ordersWithDetails,
}); });
} catch (err) { } catch (err) {
console.error("Error fetching orders:", err); console.error("Error fetching orders:", err);
return reply.status(500).send({ error: "Internal server error" }); return reply.status(500).send({ error: "Internal server error" });
@ -2627,6 +2638,7 @@ exports.getOrdersByInstallationId = async (req, reply) => {
exports.getallocatedsensorstouser= async (req, reply) => { exports.getallocatedsensorstouser= async (req, reply) => {
try { try {
const { customerId } = req.params; const { customerId } = req.params;

Loading…
Cancel
Save