fleetmap-reports 2.0.204 → 2.0.205
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 +3 -5
- package/src/zone-report.js +5 -5
package/package.json
CHANGED
package/src/util/parallel.js
CHANGED
|
@@ -23,7 +23,7 @@ exports.parallel = (report, method, toSlice, ...args) => {
|
|
|
23
23
|
reject(new Error('got empty slice'))
|
|
24
24
|
}
|
|
25
25
|
try {
|
|
26
|
-
console.log('forking worker', workerCount++, report, method, slice
|
|
26
|
+
console.log('forking worker', workerCount++, report, method, slice)
|
|
27
27
|
const worker = cluster.fork()
|
|
28
28
|
worker.send({
|
|
29
29
|
report,
|
|
@@ -37,12 +37,10 @@ exports.parallel = (report, method, toSlice, ...args) => {
|
|
|
37
37
|
resolve(_result.flat())
|
|
38
38
|
}
|
|
39
39
|
})
|
|
40
|
-
worker.on('error',
|
|
40
|
+
worker.on('error', reject)
|
|
41
41
|
worker.on('exit', (code, signal) => {
|
|
42
42
|
if (code !== 0) {
|
|
43
|
-
|
|
44
|
-
console.error(error)
|
|
45
|
-
reject(new Error(error))
|
|
43
|
+
reject(new Error(`Worker exited with code ${code} and signal ${signal}`))
|
|
46
44
|
}
|
|
47
45
|
})
|
|
48
46
|
} catch (e) {
|
package/src/zone-report.js
CHANGED
|
@@ -23,11 +23,12 @@ const { checkGeofenceIn } = require('./util/geofence')
|
|
|
23
23
|
const { parallel } = require('./util/parallel')
|
|
24
24
|
const { getDataByDay } = require('./util/trips')
|
|
25
25
|
const axios = require('axios').default
|
|
26
|
-
const sliceSize =
|
|
26
|
+
const sliceSize = 10
|
|
27
|
+
const deviceChunk = 5
|
|
27
28
|
const fileName = 'ZoneReport'
|
|
28
29
|
|
|
29
30
|
async function createZoneReport (from, to, userData, traccar) {
|
|
30
|
-
console.log('createZoneReport
|
|
31
|
+
console.log('createZoneReport', from, to)
|
|
31
32
|
const reportData = []
|
|
32
33
|
const devices = devicesToProcess(userData)
|
|
33
34
|
const allData = {
|
|
@@ -66,14 +67,13 @@ async function createZoneReport (from, to, userData, traccar) {
|
|
|
66
67
|
}
|
|
67
68
|
|
|
68
69
|
const reportRangeDays = (new Date(to).getTime() - new Date(from).getTime()) / (1000 * 60 * 60 * 24)
|
|
69
|
-
const
|
|
70
|
-
const sliced = automaticReports.sliceArray(devices, devicesPerRequest)
|
|
70
|
+
const sliced = automaticReports.sliceArray(devices, sliceSize)
|
|
71
71
|
|
|
72
72
|
let deviceCount = 0
|
|
73
73
|
for (const slice of sliced) {
|
|
74
74
|
const data = await traccarHelper.getAllInOne(
|
|
75
75
|
traccar, from, to, slice, true, false, false, false,
|
|
76
|
-
deviceCount, devices.length, sliceSize,
|
|
76
|
+
deviceCount, devices.length, sliceSize, reportRangeDays > 29 ? 1 : deviceChunk, undefined)
|
|
77
77
|
|
|
78
78
|
const route = filterPositions(data.route)
|
|
79
79
|
const alerts = []
|