electron/lib/renderer/api/web-frame.ts

85 lines
2.6 KiB
TypeScript
Raw Normal View History

2020-03-20 20:28:31 +00:00
import { EventEmitter } from 'events';
import deprecate from '@electron/internal/common/api/deprecate';
2016-01-12 02:40:23 +00:00
const binding = process._linkedBinding('electron_renderer_web_frame');
2016-01-12 02:40:23 +00:00
class WebFrame extends EventEmitter {
constructor (public context: Window) {
2020-03-20 20:28:31 +00:00
super();
2016-01-12 02:40:23 +00:00
// Lots of webview would subscribe to webFrame's events.
2020-03-20 20:28:31 +00:00
this.setMaxListeners(0);
}
2016-01-12 02:40:23 +00:00
findFrameByRoutingId (routingId: number) {
return getWebFrame(binding._findFrameByRoutingId(this.context, routingId));
}
getFrameForSelector (selector: string) {
return getWebFrame(binding._getFrameForSelector(this.context, selector));
}
findFrameByName (name: string) {
return getWebFrame(binding._findFrameByName(this.context, name));
}
get opener () {
2020-03-20 20:28:31 +00:00
return getWebFrame(binding._getOpener(this.context));
}
get parent () {
2020-03-20 20:28:31 +00:00
return getWebFrame(binding._getParent(this.context));
}
get top () {
2020-03-20 20:28:31 +00:00
return getWebFrame(binding._getTop(this.context));
}
get firstChild () {
2020-03-20 20:28:31 +00:00
return getWebFrame(binding._getFirstChild(this.context));
}
get nextSibling () {
2020-03-20 20:28:31 +00:00
return getWebFrame(binding._getNextSibling(this.context));
}
get routingId () {
2020-03-20 20:28:31 +00:00
return binding._getRoutingId(this.context);
}
}
const contextIsolation = binding.getWebPreference(window, 'contextIsolation');
const worldSafeExecuteJavaScript = binding.getWebPreference(window, 'worldSafeExecuteJavaScript');
const worldSafeJS = worldSafeExecuteJavaScript || !contextIsolation;
// Populate the methods.
for (const name in binding) {
if (!name.startsWith('_')) { // some methods are manually populated above
// TODO(felixrieseberg): Once we can type web_frame natives, we could
// use a neat `keyof` here
(WebFrame as any).prototype[name] = function (...args: Array<any>) {
if (!worldSafeJS && name.startsWith('executeJavaScript')) {
deprecate.log(`Security Warning: webFrame.${name} was called without worldSafeExecuteJavaScript enabled. This is considered unsafe. worldSafeExecuteJavaScript will be enabled by default in Electron 12.`);
}
return (binding as any)[name](this.context, ...args);
2020-03-20 20:28:31 +00:00
};
// TODO(MarshallOfSound): Remove once the above deprecation is removed
if (name.startsWith('executeJavaScript')) {
(WebFrame as any).prototype[`_${name}`] = function (...args: Array<any>) {
return (binding as any)[name](this.context, ...args);
};
}
}
}
// Helper to return WebFrame or null depending on context.
// TODO(zcbenz): Consider returning same WebFrame for the same frame.
function getWebFrame (context: Window) {
2020-03-20 20:28:31 +00:00
return context ? new WebFrame(context) : null;
}
2020-03-20 20:28:31 +00:00
const _webFrame = new WebFrame(window);
2020-03-20 20:28:31 +00:00
export default _webFrame;