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 CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "fleetmap-reports",
3
- "version": "2.0.204",
3
+ "version": "2.0.205",
4
4
  "description": "",
5
5
  "main": "src/index.js",
6
6
  "scripts": {
@@ -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.length)
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', e => { console.error(e); reject(e) })
40
+ worker.on('error', reject)
41
41
  worker.on('exit', (code, signal) => {
42
42
  if (code !== 0) {
43
- const error = `Worker exited with code ${code} and signal ${signal}`
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) {
@@ -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 = 4
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 200', from, to)
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 devicesPerRequest = reportRangeDays > 28 ? 1 : sliceSize
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, devicesPerRequest, undefined)
76
+ deviceCount, devices.length, sliceSize, reportRangeDays > 29 ? 1 : deviceChunk, undefined)
77
77
 
78
78
  const route = filterPositions(data.route)
79
79
  const alerts = []