fleetmap-reports 1.0.707 → 1.0.710
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- package/src/util/parallel.js +36 -0
- package/src/worker.js +6 -0
- package/src/zone-report.js +13 -23
package/package.json
CHANGED
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
const { sliceArray } = require('../automaticReports')
|
|
2
|
+
const cluster = require('cluster')
|
|
3
|
+
|
|
4
|
+
exports.parallel = (report, method, devices, route, userData) => {
|
|
5
|
+
const numCPUs = require('os').cpus().length
|
|
6
|
+
return new Promise((resolve) => {
|
|
7
|
+
if (cluster.isPrimary) {
|
|
8
|
+
console.log(`Master ${process.pid} is running`, process.cwd())
|
|
9
|
+
cluster.setupPrimary({
|
|
10
|
+
exec: './src/worker.js'
|
|
11
|
+
})
|
|
12
|
+
const sliced = sliceArray(devices, numCPUs)
|
|
13
|
+
const _result = []
|
|
14
|
+
let done = 0
|
|
15
|
+
sliced.forEach((_devices) => {
|
|
16
|
+
const worker = cluster.fork()
|
|
17
|
+
worker.send({
|
|
18
|
+
report,
|
|
19
|
+
method,
|
|
20
|
+
args: [_devices, route.filter(p => _devices.find(d => d.id === p.deviceId)), userData]
|
|
21
|
+
})
|
|
22
|
+
worker.on('message', ({ result }) => {
|
|
23
|
+
console.log(`Received result from worker ${worker.process.pid}:`, result)
|
|
24
|
+
_result.push(result)
|
|
25
|
+
if (++done === sliced.length) {
|
|
26
|
+
resolve(_result.flat())
|
|
27
|
+
}
|
|
28
|
+
})
|
|
29
|
+
})
|
|
30
|
+
|
|
31
|
+
cluster.on('exit', (worker, code, signal) => {
|
|
32
|
+
console.log('Worker died', worker.process.pid, code, signal)
|
|
33
|
+
})
|
|
34
|
+
}
|
|
35
|
+
})
|
|
36
|
+
}
|
package/src/worker.js
ADDED
package/src/zone-report.js
CHANGED
|
@@ -2,7 +2,8 @@ const automaticReports = require('./automaticReports')
|
|
|
2
2
|
const {
|
|
3
3
|
convertMS, convertToLocaleString, getTranslations, convertToFeature, convertPositionToFeature,
|
|
4
4
|
calculateDistance,
|
|
5
|
-
sortPositions, getDates, convertToLocaleDateString, convertToLocaleTimeString
|
|
5
|
+
sortPositions, getDates, convertToLocaleDateString, convertToLocaleTimeString,
|
|
6
|
+
isClientSide
|
|
6
7
|
} = require('./util/utils')
|
|
7
8
|
const jsPDF = require('jspdf')
|
|
8
9
|
require('jspdf-autotable')
|
|
@@ -12,9 +13,9 @@ const { getStyle } = require('./reportStyle')
|
|
|
12
13
|
const { getUserPartner } = require('fleetmap-partners')
|
|
13
14
|
const { devicesToProcess } = require('./util/device')
|
|
14
15
|
const axios = require('axios')
|
|
15
|
-
const { processServerSide } = require('./util')
|
|
16
16
|
const { filterPositions } = require('./util/route')
|
|
17
17
|
const { checkGeofenceIn } = require('./util/geofence')
|
|
18
|
+
const { parallel } = require('./util/parallel')
|
|
18
19
|
const sliceSize = 100
|
|
19
20
|
const deviceChunk = 5
|
|
20
21
|
const fileName = 'ZoneReport'
|
|
@@ -27,19 +28,10 @@ async function createZoneReport (from, to, userData, traccar) {
|
|
|
27
28
|
xpert: devices.filter(d => d.attributes.xpert).length > 0
|
|
28
29
|
}
|
|
29
30
|
|
|
30
|
-
if (
|
|
31
|
+
if (isClientSide()) {
|
|
31
32
|
const url = `https://${process.env.SERVER_HOST}/reports/zone-report`
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
for (const slice of sliced) {
|
|
35
|
-
promises.push(axios.post(url, { from, to, userData: { ...userData, devices: slice } }, { withCredentials: true })
|
|
36
|
-
.then(d => d.data)
|
|
37
|
-
.then(data => allData.devices.push(...(data[0].devices)))
|
|
38
|
-
)
|
|
39
|
-
}
|
|
40
|
-
await Promise.all(promises)
|
|
41
|
-
reportData.push(allData)
|
|
42
|
-
return reportData
|
|
33
|
+
return axios.post(url, { from, to, userData }, { withCredentials: true })
|
|
34
|
+
.then(d => d.data)
|
|
43
35
|
}
|
|
44
36
|
const types = ['geofenceEnter', 'geofenceExit']
|
|
45
37
|
|
|
@@ -75,8 +67,7 @@ async function createZoneReport (from, to, userData, traccar) {
|
|
|
75
67
|
deviceCount, devices.length, sliceSize, deviceChunk, undefined)
|
|
76
68
|
|
|
77
69
|
const route = filterPositions(data.route)
|
|
78
|
-
const alerts = await getInAndOutEvents
|
|
79
|
-
|
|
70
|
+
const alerts = await parallel('zone-report', 'getInAndOutEvents', slice, route, userData)
|
|
80
71
|
allData.devices.push(...await processDevices(from, to, devices, userData, { alerts, route }))
|
|
81
72
|
|
|
82
73
|
deviceCount = deviceCount + slice.length
|
|
@@ -304,17 +295,16 @@ async function getInAndOutEvents (devices, route, userData) {
|
|
|
304
295
|
const events = []
|
|
305
296
|
const geofencesFeatures = userData.geofences.map(g => convertToFeature(g))
|
|
306
297
|
|
|
307
|
-
|
|
298
|
+
devices.forEach(d => {
|
|
308
299
|
const deviceRoute = route.filter(p => p.deviceId === d.id)
|
|
309
300
|
const routePoints = deviceRoute.sort(sortPositions).map(p => convertPositionToFeature(p))
|
|
310
|
-
const deviceEvents = []
|
|
311
301
|
routePoints.filter(p => p.properties.position.valid).forEach((p, i, array) => {
|
|
312
302
|
p.inside = {}
|
|
313
303
|
if (!i) {
|
|
314
304
|
geofencesFeatures.forEach((g, id) => {
|
|
315
305
|
if (checkGeofenceIn(p, g)) {
|
|
316
306
|
p.inside[id] = true
|
|
317
|
-
|
|
307
|
+
events.push(createEvent('geofenceIn', d.id, p, g))
|
|
318
308
|
}
|
|
319
309
|
})
|
|
320
310
|
return
|
|
@@ -323,20 +313,19 @@ async function getInAndOutEvents (devices, route, userData) {
|
|
|
323
313
|
geofencesFeatures.forEach((g, id) => {
|
|
324
314
|
if (previous.inside[id]) {
|
|
325
315
|
if (!checkGeofenceIn(p, g)) {
|
|
326
|
-
|
|
316
|
+
events.push(createEvent('geofenceExit', d.id, p, g))
|
|
327
317
|
} else {
|
|
328
318
|
p.inside[id] = true
|
|
329
319
|
}
|
|
330
320
|
} else {
|
|
331
321
|
if (checkGeofenceIn(p, g)) {
|
|
332
322
|
p.inside[id] = true
|
|
333
|
-
|
|
323
|
+
events.push(createEvent('geofenceEnter', d.id, p, g))
|
|
334
324
|
}
|
|
335
325
|
}
|
|
336
326
|
})
|
|
337
327
|
})
|
|
338
|
-
|
|
339
|
-
}))
|
|
328
|
+
})
|
|
340
329
|
return events
|
|
341
330
|
}
|
|
342
331
|
|
|
@@ -554,3 +543,4 @@ function geofenceExit (user, row) {
|
|
|
554
543
|
exports.createZoneReport = createZoneReport
|
|
555
544
|
exports.exportZoneReportToPDF = exportZoneReportToPDF
|
|
556
545
|
exports.exportZoneReportToExcel = exportZoneReportToExcel
|
|
546
|
+
exports.getInAndOutEvents = getInAndOutEvents
|