da0fd286b4
* chore: initial scaffolding * chore: implement interface and docs * chore: address code style review * fix: cleanup of utility process on shutdown * chore: simplify NodeBindings::CreateEnvironment * chore: rename disableLibraryValidation => allowLoadingUnsignedLibraries * chore: implement process.parentPort * chore(posix): implement stdio pipe interface * chore(win): implement stdio interface * chore: reenable SetNodeOptions for utility process * chore: add specs * chore: fix lint * fix: update kill API * fix: update process.parentPort API * fix: exit event * docs: update exit event * fix: tests on linux * chore: expand on some comments * fix: shutdown of pipe reader Avoid logging since it is always the case that reader end of pipe will terminate after the child process. * fix: remove exit code check for crash spec * fix: rm PR_SET_NO_NEW_PRIVS for unsandbox utility process * chore: fix incorrect rebase * fix: address review feedback * chore: rename utility_process -> utility * chore: update docs * chore: cleanup c++ implemantation * fix: leak in NodeServiceHost impl * chore: minor cleanup * chore: cleanup JS implementation * chore: flip default stdio to inherit * fix: some api improvements * Support cwd option * Remove path restriction for modulePath * Rewire impl for env support * fix: add tests for cwd and env option * chore: alt impl for reading stdio handles * chore: support message queuing * chore: fix lint * chore: new UtilityProcess => utilityProcess.fork * fix: support for uncaught exception exits * chore: remove process.execArgv as default * fix: windows build * fix: style changes * fix: docs and style changes * chore: update patches * spec: disable flaky test on win32 arm CI Co-authored-by: PatchUp <73610968+patchup[bot]@users.noreply.github.com>
318 lines
10 KiB
TypeScript
318 lines
10 KiB
TypeScript
/// <reference path="../electron.d.ts" />
|
|
|
|
/**
|
|
* This file augments the Electron TS namespace with the internal APIs
|
|
* that are not documented but are used by Electron internally
|
|
*/
|
|
|
|
declare namespace Electron {
|
|
enum ProcessType {
|
|
browser = 'browser',
|
|
renderer = 'renderer',
|
|
worker = 'worker',
|
|
utility = 'utility'
|
|
}
|
|
|
|
interface App {
|
|
setVersion(version: string): void;
|
|
setDesktopName(name: string): void;
|
|
setAppPath(path: string | null): void;
|
|
}
|
|
|
|
type TouchBarItemType = NonNullable<Electron.TouchBarConstructorOptions['items']>[0];
|
|
|
|
interface BaseWindow {
|
|
_init(): void;
|
|
}
|
|
|
|
interface BrowserWindow {
|
|
_init(): void;
|
|
_touchBar: Electron.TouchBar | null;
|
|
_setTouchBarItems: (items: TouchBarItemType[]) => void;
|
|
_setEscapeTouchBarItem: (item: TouchBarItemType | {}) => void;
|
|
_refreshTouchBarItem: (itemID: string) => void;
|
|
_getWindowButtonVisibility: () => boolean;
|
|
frameName: string;
|
|
on(event: '-touch-bar-interaction', listener: (event: Event, itemID: string, details: any) => void): this;
|
|
removeListener(event: '-touch-bar-interaction', listener: (event: Event, itemID: string, details: any) => void): this;
|
|
}
|
|
|
|
interface BrowserWindowConstructorOptions {
|
|
webContents?: WebContents;
|
|
}
|
|
|
|
interface ContextBridge {
|
|
internalContextBridge?: {
|
|
contextIsolationEnabled: boolean;
|
|
overrideGlobalValueFromIsolatedWorld(keys: string[], value: any): void;
|
|
overrideGlobalValueWithDynamicPropsFromIsolatedWorld(keys: string[], value: any): void;
|
|
overrideGlobalPropertyFromIsolatedWorld(keys: string[], getter: Function, setter?: Function): void;
|
|
isInMainWorld(): boolean;
|
|
}
|
|
}
|
|
|
|
interface TouchBar {
|
|
_removeFromWindow: (win: BrowserWindow) => void;
|
|
}
|
|
|
|
interface WebContents {
|
|
_loadURL(url: string, options: ElectronInternal.LoadURLOptions): void;
|
|
getOwnerBrowserWindow(): Electron.BrowserWindow | null;
|
|
getLastWebPreferences(): Electron.WebPreferences | null;
|
|
_getProcessMemoryInfo(): Electron.ProcessMemoryInfo;
|
|
_getPreloadPaths(): string[];
|
|
equal(other: WebContents): boolean;
|
|
browserWindowOptions: BrowserWindowConstructorOptions;
|
|
_windowOpenHandler: ((details: Electron.HandlerDetails) => any) | null;
|
|
_callWindowOpenHandler(event: any, details: Electron.HandlerDetails): {browserWindowConstructorOptions: Electron.BrowserWindowConstructorOptions | null, outlivesOpener: boolean};
|
|
_setNextChildWebPreferences(prefs: Partial<Electron.BrowserWindowConstructorOptions['webPreferences']> & Pick<Electron.BrowserWindowConstructorOptions, 'backgroundColor'>): void;
|
|
_send(internal: boolean, channel: string, args: any): boolean;
|
|
_sendInternal(channel: string, ...args: any[]): void;
|
|
_printToPDF(options: any): Promise<Buffer>;
|
|
_print(options: any, callback?: (success: boolean, failureReason: string) => void): void;
|
|
_getPrinters(): Electron.PrinterInfo[];
|
|
_getPrintersAsync(): Promise<Electron.PrinterInfo[]>;
|
|
_init(): void;
|
|
canGoToIndex(index: number): boolean;
|
|
getActiveIndex(): number;
|
|
length(): number;
|
|
destroy(): void;
|
|
// <webview>
|
|
attachToIframe(embedderWebContents: Electron.WebContents, embedderFrameId: number): void;
|
|
detachFromOuterFrame(): void;
|
|
setEmbedder(embedder: Electron.WebContents): void;
|
|
viewInstanceId: number;
|
|
}
|
|
|
|
interface WebFrameMain {
|
|
_send(internal: boolean, channel: string, args: any): void;
|
|
_sendInternal(channel: string, ...args: any[]): void;
|
|
_postMessage(channel: string, message: any, transfer?: any[]): void;
|
|
}
|
|
|
|
interface WebFrame {
|
|
_isEvalAllowed(): boolean;
|
|
}
|
|
|
|
interface WebPreferences {
|
|
disablePopups?: boolean;
|
|
embedder?: Electron.WebContents;
|
|
type?: 'backgroundPage' | 'window' | 'browserView' | 'remote' | 'webview' | 'offscreen';
|
|
}
|
|
|
|
interface Menu {
|
|
_init(): void;
|
|
_isCommandIdChecked(id: string): boolean;
|
|
_isCommandIdEnabled(id: string): boolean;
|
|
_shouldCommandIdWorkWhenHidden(id: string): boolean;
|
|
_isCommandIdVisible(id: string): boolean;
|
|
_getAcceleratorForCommandId(id: string, useDefaultAccelerator: boolean): Accelerator | undefined;
|
|
_shouldRegisterAcceleratorForCommandId(id: string): boolean;
|
|
_getSharingItemForCommandId(id: string): SharingItem | null;
|
|
_callMenuWillShow(): void;
|
|
_executeCommand(event: any, id: number): void;
|
|
_menuWillShow(): void;
|
|
commandsMap: Record<string, MenuItem>;
|
|
groupsMap: Record<string, MenuItem[]>;
|
|
getItemCount(): number;
|
|
popupAt(window: BaseWindow, x: number, y: number, positioning: number, callback: () => void): void;
|
|
closePopupAt(id: number): void;
|
|
setSublabel(index: number, label: string): void;
|
|
setToolTip(index: number, tooltip: string): void;
|
|
setIcon(index: number, image: string | NativeImage): void;
|
|
setRole(index: number, role: string): void;
|
|
insertItem(index: number, commandId: number, label: string): void;
|
|
insertCheckItem(index: number, commandId: number, label: string): void;
|
|
insertRadioItem(index: number, commandId: number, label: string, groupId: number): void;
|
|
insertSeparator(index: number): void;
|
|
insertSubMenu(index: number, commandId: number, label: string, submenu?: Menu): void;
|
|
delegate?: any;
|
|
_getAcceleratorTextAt(index: number): string;
|
|
}
|
|
|
|
interface MenuItem {
|
|
overrideReadOnlyProperty(property: string, value: any): void;
|
|
groupId: number;
|
|
getDefaultRoleAccelerator(): Accelerator | undefined;
|
|
getCheckStatus(): boolean;
|
|
acceleratorWorksWhenHidden?: boolean;
|
|
}
|
|
|
|
interface IpcMainEvent {
|
|
sendReply(value: any): void;
|
|
}
|
|
|
|
interface IpcMainInvokeEvent {
|
|
sendReply(value: any): void;
|
|
_reply(value: any): void;
|
|
_throw(error: Error | string): void;
|
|
}
|
|
|
|
class View {}
|
|
|
|
// Experimental views API
|
|
class BaseWindow {
|
|
constructor(args: {show: boolean})
|
|
setContentView(view: View): void
|
|
static fromId(id: number): BaseWindow;
|
|
static getAllWindows(): BaseWindow[];
|
|
isFocused(): boolean;
|
|
static getFocusedWindow(): BaseWindow | undefined;
|
|
setMenu(menu: Menu): void;
|
|
}
|
|
class WebContentsView {
|
|
constructor(options: BrowserWindowConstructorOptions)
|
|
}
|
|
|
|
// Deprecated / undocumented BrowserWindow methods
|
|
interface BrowserWindow {
|
|
getURL(): string;
|
|
send(channel: string, ...args: any[]): void;
|
|
openDevTools(options?: Electron.OpenDevToolsOptions): void;
|
|
closeDevTools(): void;
|
|
isDevToolsOpened(): void;
|
|
isDevToolsFocused(): void;
|
|
toggleDevTools(): void;
|
|
inspectElement(x: number, y: number): void;
|
|
inspectSharedWorker(): void;
|
|
inspectServiceWorker(): void;
|
|
getBackgroundThrottling(): void;
|
|
setBackgroundThrottling(allowed: boolean): void;
|
|
}
|
|
|
|
namespace Main {
|
|
class BaseWindow extends Electron.BaseWindow {}
|
|
class View extends Electron.View {}
|
|
class WebContentsView extends Electron.WebContentsView {}
|
|
}
|
|
}
|
|
|
|
declare namespace ElectronInternal {
|
|
interface DesktopCapturer {
|
|
startHandling(captureWindow: boolean, captureScreen: boolean, thumbnailSize: Electron.Size, fetchWindowIcons: boolean): void;
|
|
_onerror?: (error: string) => void;
|
|
_onfinished?: (sources: Electron.DesktopCapturerSource[], fetchWindowIcons: boolean) => void;
|
|
}
|
|
|
|
interface GetSourcesOptions {
|
|
captureWindow: boolean;
|
|
captureScreen: boolean;
|
|
thumbnailSize: Electron.Size;
|
|
fetchWindowIcons: boolean;
|
|
}
|
|
|
|
interface GetSourcesResult {
|
|
id: string;
|
|
name: string;
|
|
thumbnail: Electron.NativeImage;
|
|
display_id: string;
|
|
appIcon: Electron.NativeImage | null;
|
|
}
|
|
|
|
interface IpcRendererInternal extends NodeJS.EventEmitter, Pick<Electron.IpcRenderer, 'send' | 'sendSync' | 'invoke'> {
|
|
invoke<T>(channel: string, ...args: any[]): Promise<T>;
|
|
}
|
|
|
|
interface IpcMainInternalEvent extends Omit<Electron.IpcMainEvent, 'reply'> {
|
|
}
|
|
|
|
interface IpcMainInternal extends NodeJS.EventEmitter {
|
|
handle(channel: string, listener: (event: Electron.IpcMainInvokeEvent, ...args: any[]) => Promise<any> | any): void;
|
|
on(channel: string, listener: (event: IpcMainInternalEvent, ...args: any[]) => void): this;
|
|
once(channel: string, listener: (event: IpcMainInternalEvent, ...args: any[]) => void): this;
|
|
}
|
|
|
|
interface Event extends Electron.Event {
|
|
sender: WebContents;
|
|
}
|
|
|
|
interface LoadURLOptions extends Electron.LoadURLOptions {
|
|
reloadIgnoringCache?: boolean;
|
|
}
|
|
|
|
interface WebContentsPrintOptions extends Electron.WebContentsPrintOptions {
|
|
mediaSize?: MediaSize;
|
|
}
|
|
|
|
type MediaSize = {
|
|
name: string,
|
|
custom_display_name: string,
|
|
height_microns: number,
|
|
width_microns: number,
|
|
is_default?: 'true',
|
|
}
|
|
|
|
type PageSize = {
|
|
width: number,
|
|
height: number,
|
|
}
|
|
|
|
type ModuleLoader = () => any;
|
|
|
|
interface ModuleEntry {
|
|
name: string;
|
|
private?: boolean;
|
|
loader: ModuleLoader;
|
|
}
|
|
|
|
interface UtilityProcessWrapper extends NodeJS.EventEmitter {
|
|
readonly pid: (number) | (undefined);
|
|
kill(): boolean;
|
|
postMessage(message: any, transfer?: any[]): void;
|
|
}
|
|
|
|
interface ParentPort extends NodeJS.EventEmitter {
|
|
start(): void;
|
|
pause(): void;
|
|
postMessage(message: any): void;
|
|
}
|
|
|
|
class WebViewElement extends HTMLElement {
|
|
static observedAttributes: Array<string>;
|
|
|
|
public contentWindow: Window;
|
|
|
|
public connectedCallback?(): void;
|
|
public attributeChangedCallback?(): void;
|
|
public disconnectedCallback?(): void;
|
|
|
|
// Created in web-view-impl
|
|
public getWebContentsId(): number;
|
|
public capturePage(rect?: Electron.Rectangle): Promise<Electron.NativeImage>;
|
|
}
|
|
|
|
class WebContents extends Electron.WebContents {
|
|
static create(opts: Electron.WebPreferences): Electron.WebContents;
|
|
}
|
|
}
|
|
|
|
declare namespace Chrome {
|
|
namespace Tabs {
|
|
// https://developer.chrome.com/docs/extensions/tabs#method-executeScript
|
|
interface ExecuteScriptDetails {
|
|
code?: string;
|
|
file?: string;
|
|
allFrames?: boolean;
|
|
frameId?: number;
|
|
matchAboutBlank?: boolean;
|
|
runAt?: 'document-start' | 'document-end' | 'document_idle';
|
|
cssOrigin: 'author' | 'user';
|
|
}
|
|
|
|
type ExecuteScriptCallback = (result: Array<any>) => void;
|
|
|
|
// https://developer.chrome.com/docs/extensions/tabs#method-sendMessage
|
|
interface SendMessageDetails {
|
|
frameId?: number;
|
|
}
|
|
|
|
type SendMessageCallback = (result: any) => void;
|
|
}
|
|
}
|
|
|
|
interface Global extends NodeJS.Global {
|
|
require: NodeRequire;
|
|
module: NodeModule;
|
|
__filename: string;
|
|
__dirname: string;
|
|
}
|