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 CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "fleetmap-reports",
3
- "version": "1.0.707",
3
+ "version": "1.0.710",
4
4
  "description": "",
5
5
  "main": "src/index.js",
6
6
  "scripts": {
@@ -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
@@ -0,0 +1,6 @@
1
+ process.on('message', async (message) => {
2
+ const { report, method, args } = message
3
+ console.log(message)
4
+ const _report = require(`./${report}`)
5
+ process.send({ result: await _report[method](...args) })
6
+ })
@@ -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 (processServerSide(userData)) {
31
+ if (isClientSide()) {
31
32
  const url = `https://${process.env.SERVER_HOST}/reports/zone-report`
32
- const sliced = automaticReports.sliceArray(devices, sliceSize)
33
- const promises = []
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(slice, route, userData)
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
- await Promise.all(devices.map(async d => {
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
- deviceEvents.push(createEvent('geofenceIn', d.id, p, g))
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
- deviceEvents.push(createEvent('geofenceExit', d.id, p, g))
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
- deviceEvents.push(createEvent('geofenceEnter', d.id, p, g))
323
+ events.push(createEvent('geofenceEnter', d.id, p, g))
334
324
  }
335
325
  }
336
326
  })
337
327
  })
338
- events.push(...deviceEvents)
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