2017-05-08 13:30:45 -05:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
const systemIdleTime = require('@paulcbetts/system-idle-time');
|
|
|
|
const throttle = require('../utils/throttle');
|
2017-05-31 23:39:08 -05:00
|
|
|
const log = require('../log.js');
|
|
|
|
const logLevels = require('../enums/logLevels.js');
|
2017-05-08 13:30:45 -05:00
|
|
|
|
2018-08-28 01:17:09 -05:00
|
|
|
let setIsAutoReloadFnc;
|
|
|
|
let getIsOnlineFnc;
|
2018-04-11 08:06:46 -05:00
|
|
|
if (!process.env.ELECTRON_QA) {
|
|
|
|
/* eslint-disable global-require */
|
2018-08-28 01:17:09 -05:00
|
|
|
const { getIsOnline, setIsAutoReload } = require('../windowMgr');
|
|
|
|
getIsOnlineFnc = getIsOnline;
|
|
|
|
setIsAutoReloadFnc = setIsAutoReload;
|
2018-04-11 08:06:46 -05:00
|
|
|
/* eslint-enable global-require */
|
|
|
|
}
|
|
|
|
|
2017-05-08 13:30:45 -05:00
|
|
|
let maxIdleTime;
|
|
|
|
let activityWindow;
|
|
|
|
let intervalId;
|
|
|
|
let throttleActivity;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check if the user is idle
|
|
|
|
*/
|
|
|
|
function activityDetection() {
|
|
|
|
// Get system idle status and idle time from PaulCBetts package
|
|
|
|
if (systemIdleTime.getIdleTime() < maxIdleTime) {
|
2017-08-23 11:38:33 -05:00
|
|
|
return { isUserIdle: false, systemIdleTime: systemIdleTime.getIdleTime() };
|
2017-05-08 13:30:45 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// If idle for more than 4 mins, monitor system idle status every second
|
|
|
|
if (!intervalId) {
|
|
|
|
monitorUserActivity();
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Start monitoring user activity status.
|
|
|
|
* Run every 4 mins to check user idle status
|
|
|
|
*/
|
|
|
|
function initiateActivityDetection() {
|
|
|
|
|
|
|
|
if (!throttleActivity) {
|
|
|
|
throttleActivity = throttle(maxIdleTime, sendActivity);
|
|
|
|
setInterval(throttleActivity, maxIdleTime);
|
|
|
|
}
|
|
|
|
|
|
|
|
sendActivity();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Monitor system idle status every second
|
|
|
|
*/
|
|
|
|
function monitorUserActivity() {
|
|
|
|
intervalId = setInterval(monitor, 1000);
|
|
|
|
|
|
|
|
function monitor() {
|
2018-08-28 01:17:09 -05:00
|
|
|
if (systemIdleTime.getIdleTime() < maxIdleTime && typeof getIsOnlineFnc === 'function' && getIsOnlineFnc()) {
|
2017-05-08 13:30:45 -05:00
|
|
|
// If system is active, send an update to the app bridge and clear the timer
|
|
|
|
sendActivity();
|
2018-08-28 01:17:09 -05:00
|
|
|
if (typeof setIsAutoReloadFnc === 'function') {
|
|
|
|
setIsAutoReloadFnc(false);
|
2018-04-11 08:06:46 -05:00
|
|
|
}
|
2017-05-08 13:30:45 -05:00
|
|
|
clearInterval(intervalId);
|
|
|
|
intervalId = undefined;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Send user activity status to the app bridge
|
|
|
|
* to be updated across all clients
|
|
|
|
*/
|
|
|
|
function sendActivity() {
|
|
|
|
let systemActivity = activityDetection();
|
|
|
|
if (systemActivity && !systemActivity.isUserIdle && systemActivity.systemIdleTime) {
|
2017-08-23 11:38:33 -05:00
|
|
|
send({ systemIdleTime: systemActivity.systemIdleTime });
|
2017-05-08 13:30:45 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sends user activity status from main process to activity detection hosted by
|
|
|
|
* renderer process. Allows main process to use activity detection
|
|
|
|
* provided by JS.
|
|
|
|
* @param {object} data - data as object
|
|
|
|
*/
|
|
|
|
function send(data) {
|
|
|
|
if (activityWindow && data) {
|
2017-05-31 23:39:08 -05:00
|
|
|
log.send(logLevels.INFO, 'activity occurred at time= ' + new Date().toUTCString());
|
2017-05-08 13:30:45 -05:00
|
|
|
activityWindow.send('activity', {
|
|
|
|
systemIdleTime: data.systemIdleTime
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-08-24 05:48:32 -05:00
|
|
|
/**
|
|
|
|
* Set the activity's window
|
|
|
|
* @param period
|
|
|
|
* @param win
|
|
|
|
*/
|
2017-05-08 13:30:45 -05:00
|
|
|
function setActivityWindow(period, win) {
|
|
|
|
maxIdleTime = period;
|
|
|
|
activityWindow = win;
|
2017-05-27 10:16:23 -05:00
|
|
|
// Initiate activity detection to monitor user activity status
|
|
|
|
initiateActivityDetection();
|
2017-05-08 13:30:45 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = {
|
|
|
|
send: send,
|
|
|
|
setActivityWindow: setActivityWindow,
|
2017-05-10 11:12:00 -05:00
|
|
|
activityDetection: activityDetection,
|
2017-08-24 02:51:02 -05:00
|
|
|
monitorUserActivity: monitorUserActivity, // Exporting this for unit tests
|
2017-08-23 11:38:33 -05:00
|
|
|
};
|