mirror of
https://github.com/finos/SymphonyElectron.git
synced 2025-01-15 19:22:13 -06:00
4087eb3acc
* Implemented user activity detection * ELECTRON-32: Implemented throttle function * ELECTRON-32: Fixed some bugs in throttle function * ELECTRON-32: Updated comments * ELECTRON-32: Fixed clear interval bug * ELECTRON-32: Updated as per the review * ELECTRON-32: Updated return statement * ELECTRON-32: Added a boolean to the callback function * ELECTRON-32: Resolved conflicts * ELECTRON-32 - Added period attribute
104 lines
2.9 KiB
JavaScript
104 lines
2.9 KiB
JavaScript
'use strict';
|
|
|
|
/**
|
|
* This module runs in the main process and handles api calls
|
|
* from the renderer process.
|
|
*/
|
|
const electron = require('electron');
|
|
|
|
const windowMgr = require('./windowMgr.js');
|
|
const log = require('./log.js');
|
|
const activityDetection = require('./activityDetection/activityDetection');
|
|
const badgeCount = require('./badgeCount.js');
|
|
|
|
const apiEnums = require('./enums/api.js');
|
|
const apiCmds = apiEnums.cmds;
|
|
const apiName = apiEnums.apiName;
|
|
|
|
// can be overridden for testing
|
|
let checkValidWindow = true;
|
|
|
|
/**
|
|
* Ensure events comes from a window that we have created.
|
|
* @param {EventEmitter} event node emitter event to be tested
|
|
* @return {Boolean} returns true if exists otherwise false
|
|
*/
|
|
function isValidWindow(event) {
|
|
if (!checkValidWindow) {
|
|
return true;
|
|
}
|
|
var result = false;
|
|
if (event && event.sender) {
|
|
// validate that event sender is from window we created
|
|
const browserWin = electron.BrowserWindow.fromWebContents(event.sender);
|
|
const winKey = event.sender.browserWindowOptions &&
|
|
event.sender.browserWindowOptions.winKey;
|
|
|
|
result = windowMgr.hasWindow(browserWin, winKey);
|
|
}
|
|
|
|
if (!result) {
|
|
/* eslint-disable no-console */
|
|
console.log('invalid window try to perform action, ignoring action');
|
|
/* eslint-enable no-console */
|
|
}
|
|
|
|
return result;
|
|
}
|
|
|
|
/**
|
|
* Handle API related ipc messages from renderers. Only messages from windows
|
|
* we have created are allowed.
|
|
*/
|
|
electron.ipcMain.on(apiName, (event, arg) => {
|
|
if (!isValidWindow(event)) {
|
|
return;
|
|
}
|
|
|
|
if (!arg) {
|
|
return;
|
|
}
|
|
|
|
if (arg.cmd === apiCmds.isOnline && typeof arg.isOnline === 'boolean') {
|
|
windowMgr.setIsOnline(arg.isOnline);
|
|
return;
|
|
}
|
|
|
|
if (arg.cmd === apiCmds.setBadgeCount && typeof arg.count === 'number') {
|
|
badgeCount.show(arg.count);
|
|
return;
|
|
}
|
|
|
|
if (arg.cmd === apiCmds.badgeDataUrl && typeof arg.dataUrl === 'string' &&
|
|
typeof arg.count === 'number') {
|
|
badgeCount.setDataUrl(arg.dataUrl, arg.count);
|
|
return;
|
|
}
|
|
|
|
if (arg.cmd === apiCmds.activate && typeof arg.windowName === 'string') {
|
|
windowMgr.activate(arg.windowName);
|
|
return;
|
|
}
|
|
|
|
if (arg.cmd === apiCmds.registerBoundsChange) {
|
|
windowMgr.setBoundsChangeWindow(event.sender);
|
|
}
|
|
|
|
if (arg.cmd === apiCmds.registerLogger) {
|
|
// renderer window that has a registered logger from JS.
|
|
log.setLogWindow(event.sender);
|
|
}
|
|
|
|
if (arg.cmd === apiCmds.registerActivityDetection) {
|
|
// renderer window that has a registered activity detection from JS.
|
|
activityDetection.setActivityWindow(arg.period, event.sender);
|
|
}
|
|
});
|
|
|
|
// expose these methods primarily for testing...
|
|
module.exports = {
|
|
shouldCheckValidWindow: function (shouldCheck) {
|
|
checkValidWindow = shouldCheck;
|
|
}
|
|
}
|