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
|
|
|
|
|
|
|
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) {
|
|
|
|
return {isUserIdle: false, systemIdleTime: systemIdleTime.getIdleTime()};
|
|
|
|
}
|
|
|
|
|
|
|
|
// 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() {
|
|
|
|
if (systemIdleTime.getIdleTime() < maxIdleTime) {
|
|
|
|
// If system is active, send an update to the app bridge and clear the timer
|
|
|
|
sendActivity();
|
|
|
|
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) {
|
|
|
|
send({systemIdleTime: systemActivity.systemIdleTime});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 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
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
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-06-02 11:29:31 -05:00
|
|
|
monitorUserActivity: monitorUserActivity, // Exporting this for unit test
|
2017-05-08 13:30:45 -05:00
|
|
|
initiateActivityDetection: initiateActivityDetection
|
|
|
|
};
|