2
2
mirror of https://github.com/Llewellynvdm/nativefier.git synced 2025-01-22 14:48:28 +00:00

Warn on old Electron/Chrome (fix #556) (PR #1076)

Co-authored-by: Ronan Jouchet <ronan@jouchet.fr>
This commit is contained in:
Matthew Ruzzi 2020-11-30 18:45:35 -08:00 committed by GitHub
parent 3e0011a29c
commit e8d3530b43
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 174 additions and 137 deletions

View File

@ -3,7 +3,13 @@ import 'source-map-support/register';
import fs from 'fs'; import fs from 'fs';
import path from 'path'; import path from 'path';
import { app, crashReporter, globalShortcut, BrowserWindow } from 'electron'; import {
app,
crashReporter,
globalShortcut,
BrowserWindow,
dialog,
} from 'electron';
import electronDownload from 'electron-dl'; import electronDownload from 'electron-dl';
import { createLoginWindow } from './components/loginWindow'; import { createLoginWindow } from './components/loginWindow';
@ -20,6 +26,10 @@ if (require('electron-squirrel-startup')) {
const APP_ARGS_FILE_PATH = path.join(__dirname, '..', 'nativefier.json'); const APP_ARGS_FILE_PATH = path.join(__dirname, '..', 'nativefier.json');
const appArgs = JSON.parse(fs.readFileSync(APP_ARGS_FILE_PATH, 'utf8')); const appArgs = JSON.parse(fs.readFileSync(APP_ARGS_FILE_PATH, 'utf8'));
const OLD_BUILD_WARNING_THRESHOLD_DAYS = 60;
const OLD_BUILD_WARNING_THRESHOLD_MS =
OLD_BUILD_WARNING_THRESHOLD_DAYS * 24 * 60 * 60 * 1000;
const fileDownloadOptions = { ...appArgs.fileDownloadOptions }; const fileDownloadOptions = { ...appArgs.fileDownloadOptions };
electronDownload(fileDownloadOptions); electronDownload(fileDownloadOptions);
@ -159,6 +169,18 @@ if (shouldQuit) {
}); });
}); });
} }
if (
!appArgs.disableOldBuildWarning &&
new Date().getTime() - appArgs.buildDate > OLD_BUILD_WARNING_THRESHOLD_MS
) {
// eslint-disable-next-line @typescript-eslint/no-floating-promises
dialog.showMessageBox(null, {
type: 'warning',
message: 'Old build detected',
detail:
'This app was built a long time ago. Nativefier uses the Chrome browser (through Electron), and it is dangerous to keep using an old version of it. You should rebuild this app with a recent Electron. Using the latest Nativefier will default to it, or you can pass it manually.',
});
}
}); });
} }

View File

@ -5,71 +5,72 @@
- [Table of Contents](#table-of-contents) - [Table of Contents](#table-of-contents)
- [Packaging Squirrel-based installers](#packaging-squirrel-based-installers) - [Packaging Squirrel-based installers](#packaging-squirrel-based-installers)
- [Command Line](#command-line) - [Command Line](#command-line)
- [Target Url](#target-url) - [Target Url](#target-url)
- [[dest]](#dest) - [[dest]](#dest)
- [Help](#help) - [Help](#help)
- [Version](#version) - [Version](#version)
- [[name]](#name) - [[name]](#name)
- [[platform]](#platform) - [[platform]](#platform)
- [[arch]](#arch) - [[arch]](#arch)
- [[app-copyright]](#app-copyright) - [[app-copyright]](#app-copyright)
- [[app-version]](#app-version) - [[app-version]](#app-version)
- [[build-version]](#build-version) - [[build-version]](#build-version)
- [[electron-version]](#electron-version) - [[electron-version]](#electron-version)
- [[widevine]](#widevine) - [[widevine]](#widevine)
- [[no-overwrite]](#no-overwrite) - [[no-overwrite]](#no-overwrite)
- [[conceal]](#conceal) - [[conceal]](#conceal)
- [[icon]](#icon) - [[icon]](#icon)
- [Packaging for Windows](#packaging-for-windows) - [Packaging for Windows](#packaging-for-windows)
- [Packaging for Linux](#packaging-for-linux) - [Packaging for Linux](#packaging-for-linux)
- [Packaging for macOS](#packaging-for-macos) - [Packaging for macOS](#packaging-for-macos)
- [Manually Converting `.icns`](#manually-converting-icns) - [Manually Converting `.icns`](#manually-converting-icns)
- [[counter]](#counter) - [[counter]](#counter)
- [[bounce]](#bounce) - [[bounce]](#bounce)
- [[width]](#width) - [[width]](#width)
- [[height]](#height) - [[height]](#height)
- [[min-width]](#min-width) - [[min-width]](#min-width)
- [[min-height]](#min-height) - [[min-height]](#min-height)
- [[max-width]](#max-width) - [[max-width]](#max-width)
- [[max-height]](#max-height) - [[max-height]](#max-height)
- [[x]](#x) - [[x]](#x)
- [[y]](#y) - [[y]](#y)
- [[show-menu-bar]](#show-menu-bar) - [[show-menu-bar]](#show-menu-bar)
- [[fast-quit]](#fast-quit) - [[fast-quit]](#fast-quit)
- [[user-agent]](#user-agent) - [[user-agent]](#user-agent)
- [[honest]](#honest) - [[honest]](#honest)
- [[ignore-certificate]](#ignore-certificate) - [[ignore-certificate]](#ignore-certificate)
- [[disable-gpu]](#disable-gpu) - [[disable-gpu]](#disable-gpu)
- [[ignore-gpu-blacklist]](#ignore-gpu-blacklist) - [[ignore-gpu-blacklist]](#ignore-gpu-blacklist)
- [[enable-es3-apis]](#enable-es3-apis) - [[enable-es3-apis]](#enable-es3-apis)
- [[insecure]](#insecure) - [[insecure]](#insecure)
- [[internal-urls]](#internal-urls) - [[internal-urls]](#internal-urls)
- [[block-external-urls]](#block-external-urls) - [[block-external-urls]](#block-external-urls)
- [[proxy-rules]](#proxy-rules) - [[proxy-rules]](#proxy-rules)
- [[flash]](#flash) - [[flash]](#flash)
- [[flash-path]](#flash-path) - [[flash-path]](#flash-path)
- [[disk-cache-size]](#disk-cache-size) - [[disk-cache-size]](#disk-cache-size)
- [[inject]](#inject) - [[inject]](#inject)
- [[full-screen]](#full-screen) - [[full-screen]](#full-screen)
- [[maximize]](#maximize) - [[maximize]](#maximize)
- [[hide-window-frame]](#hide-window-frame) - [[hide-window-frame]](#hide-window-frame)
- [[title-bar-style]](#title-bar-style) - [[title-bar-style]](#title-bar-style)
- [[verbose]](#verbose) - [[verbose]](#verbose)
- [[disable-context-menu]](#disable-context-menu) - [[disable-context-menu]](#disable-context-menu)
- [[disable-dev-tools]](#disable-dev-tools) - [[disable-dev-tools]](#disable-dev-tools)
- [[crash-reporter]](#crash-reporter) - [[crash-reporter]](#crash-reporter)
- [[zoom]](#zoom) - [[zoom]](#zoom)
- [[single-instance]](#single-instance) - [[single-instance]](#single-instance)
- [[clear-cache]](#clear-cache) - [[clear-cache]](#clear-cache)
- [[tray]](#tray) - [[tray]](#tray)
- [[basic-auth-username]](#basic-auth-username) - [[basic-auth-username]](#basic-auth-username)
- [[processEnvs]](#processenvs) - [[processEnvs]](#processenvs)
- [[file-download-options]](#file-download-options) - [[file-download-options]](#file-download-options)
- [[always-on-top]](#always-on-top) - [[always-on-top]](#always-on-top)
- [[global-shortcuts]](#global-shortcuts) - [[global-shortcuts]](#global-shortcuts)
- [[browserwindow-options]](#browserwindow-options) - [[browserwindow-options]](#browserwindow-options)
- [[darwin-dark-mode-support]](#darwin-dark-mode-support) - [[darwin-dark-mode-support]](#darwin-dark-mode-support)
- [[background-color]](#background-color) - [[background-color]](#background-color)
- [[disable-old-build-warning-yesiknowitisinsecure]](#disable-old-build-warning-yesiknowitisinsecure)
- [Programmatic API](#programmatic-api) - [Programmatic API](#programmatic-api)
- [Addition packaging options for Windows](#addition-packaging-options-for-windows) - [Addition packaging options for Windows](#addition-packaging-options-for-windows)
- [[version-string]](#version-string) - [[version-string]](#version-string)
@ -85,6 +86,7 @@ See [PR #744 - Support packaging nativefier applications into Squirrel-based ins
```bash ```bash
nativefier [options] <targetUrl> [dest] nativefier [options] <targetUrl> [dest]
``` ```
Command line options are listed below. Command line options are listed below.
#### Target Url #### Target Url
@ -126,6 +128,7 @@ The name of the application, which will affect strings in titles and the icon.
``` ```
-p, --platform <value> -p, --platform <value>
``` ```
Automatically determined based on the current OS. Can be overwritten by specifying either `linux`, `windows`, `osx` or `mas` for a Mac App Store specific build. Automatically determined based on the current OS. Can be overwritten by specifying either `linux`, `windows`, `osx` or `mas` for a Mac App Store specific build.
The alternative values `win32` (for Windows) or `darwin`, `mac` (for macOS) can also be used. The alternative values `win32` (for Windows) or `darwin`, `mac` (for macOS) can also be used.
@ -137,8 +140,9 @@ The alternative values `win32` (for Windows) or `darwin`, `mac` (for macOS) can
``` ```
The processor architecture to target when building. The processor architecture to target when building.
- Automatically set to the build-time machine architecture...
- ... or can be overridden by specifying one of: `x64`, `arm`, `arm64`, `ia32`. - Automatically set to the build-time machine architecture...
- ... or can be overridden by specifying one of: `x64`, `arm`, `arm64`, `ia32`.
#### [app-copyright] #### [app-copyright]
@ -331,6 +335,7 @@ Set the user agent to run the created app with.
``` ```
--honest --honest
``` ```
By default, Nativefier uses a preset user agent string for your OS and masquerades as a regular Google Chrome browser, so that sites like WhatsApp Web will not say that the current browser is unsupported. By default, Nativefier uses a preset user agent string for your OS and masquerades as a regular Google Chrome browser, so that sites like WhatsApp Web will not say that the current browser is unsupported.
If this flag is passed, it will not override the user agent. If this flag is passed, it will not override the user agent.
@ -340,6 +345,7 @@ If this flag is passed, it will not override the user agent.
``` ```
--ignore-certificate --ignore-certificate
``` ```
Forces the packaged app to ignore certificate errors. Forces the packaged app to ignore certificate errors.
#### [disable-gpu] #### [disable-gpu]
@ -347,6 +353,7 @@ Forces the packaged app to ignore certificate errors.
``` ```
--disable-gpu --disable-gpu
``` ```
Disable hardware acceleration for the packaged application. Disable hardware acceleration for the packaged application.
#### [ignore-gpu-blacklist] #### [ignore-gpu-blacklist]
@ -354,6 +361,7 @@ Disable hardware acceleration for the packaged application.
``` ```
--ignore-gpu-blacklist --ignore-gpu-blacklist
``` ```
Passes the ignore-gpu-blacklist flag to the Chrome engine, to allow for WebGl apps to work on non supported graphics cards. Passes the ignore-gpu-blacklist flag to the Chrome engine, to allow for WebGl apps to work on non supported graphics cards.
#### [enable-es3-apis] #### [enable-es3-apis]
@ -361,22 +369,23 @@ Passes the ignore-gpu-blacklist flag to the Chrome engine, to allow for WebGl ap
``` ```
--enable-es3-apis --enable-es3-apis
``` ```
Passes the enable-es3-apis flag to the Chrome engine, to force the activation of WebGl 2.0.
Passes the enable-es3-apis flag to the Chrome engine, to force the activation of WebGl 2.0.
#### [insecure] #### [insecure]
``` ```
--insecure --insecure
``` ```
Forces the packaged app to ignore web security errors, such as [Mixed Content](https://developer.mozilla.org/en-US/docs/Security/Mixed_content) errors when receiving HTTP content on a HTTPS site.
Forces the packaged app to ignore web security errors, such as [Mixed Content](https://developer.mozilla.org/en-US/docs/Security/Mixed_content) errors when receiving HTTP content on a HTTPS site.
#### [internal-urls] #### [internal-urls]
``` ```
--internal-urls <regex> --internal-urls <regex>
``` ```
Regular expression of URLs to consider "internal"; all other URLs will be opened in an external browser. Defaults to URLs on same second-level domain as app. Regular expression of URLs to consider "internal"; all other URLs will be opened in an external browser. Defaults to URLs on same second-level domain as app.
Example: Example:
@ -444,6 +453,7 @@ You can also specify the path to the Chrome flash plugin directly with this flag
``` ```
--disk-cache-size <value> --disk-cache-size <value>
``` ```
Forces the maximum disk space to be used by the disk cache. Value is given in bytes. Forces the maximum disk space to be used by the disk cache. Value is given in bytes.
#### [inject] #### [inject]
@ -470,7 +480,6 @@ nativefier http://google.com --inject ./some-js-injection.js --inject ./some-css
Makes the packaged app start in full screen. Makes the packaged app start in full screen.
#### [maximize] #### [maximize]
``` ```
@ -479,7 +488,6 @@ Makes the packaged app start in full screen.
Makes the packaged app start maximized. Makes the packaged app start maximized.
#### [hide-window-frame] #### [hide-window-frame]
``` ```
@ -602,7 +610,6 @@ When the optional argument `start-in-tray` is provided, i.e. the application is
Set basic http(s) auth via the command line to have the app automatically log you in to a protected site. Both fields are required if one is set. Set basic http(s) auth via the command line to have the app automatically log you in to a protected site. Both fields are required if one is set.
#### [processEnvs] #### [processEnvs]
``` ```
@ -623,7 +630,7 @@ nativefier <your-geolocation-enabled-website> --processEnvs '{"GOOGLE_API_KEY":
--file-download-options <json-string> --file-download-options <json-string>
``` ```
a JSON string of key/value pairs to be set as file download options. See [electron-dl](https://github.com/sindresorhus/electron-dl) for available options. a JSON string of key/value pairs to be set as file download options. See [electron-dl](https://github.com/sindresorhus/electron-dl) for available options.
Example: Example:
@ -649,23 +656,22 @@ Register global shortcuts which will trigger input events like key presses or po
You may define multiple global shortcuts which can trigger a series of input events. It has the following structure: You may define multiple global shortcuts which can trigger a series of input events. It has the following structure:
```js ```js
[ [
{ {
// Key is passed as first argument to globalShortcut.register // Key is passed as first argument to globalShortcut.register
"key": "CommandOrControl+Shift+Z", key: 'CommandOrControl+Shift+Z',
// The input events exactly match the event config in Electron for contents.sendInputEvent(event) // The input events exactly match the event config in Electron for contents.sendInputEvent(event)
"inputEvents": [ inputEvents: [
{ {
// Available event types: mouseDown, mouseUp, mouseEnter, mouseLeave, contextMenu, mouseWheel, mouseMove, keyDown, keyUp or char // Available event types: mouseDown, mouseUp, mouseEnter, mouseLeave, contextMenu, mouseWheel, mouseMove, keyDown, keyUp or char
"type": "keyDown", type: 'keyDown',
// Further config depends on your event type. See docs at: https://github.com/electron/electron/blob/master/docs/api/web-contents.md#contentssendinputeventevent // Further config depends on your event type. See docs at: https://github.com/electron/electron/blob/master/docs/api/web-contents.md#contentssendinputeventevent
"keyCode": "Space" keyCode: 'Space',
} },
] ],
} },
] ];
``` ```
**Important note for using modifier keys:** **Important note for using modifier keys:**
@ -674,10 +680,11 @@ If you want to trigger key events which include a modifier (Ctrl, Shift,...), yo
**For more details, please see the Electron documentation:** **For more details, please see the Electron documentation:**
* List of available keys: https://github.com/electron/electron/blob/master/docs/api/accelerator.md - List of available keys: https://github.com/electron/electron/blob/master/docs/api/accelerator.md
* Details about how to create input event objects: https://github.com/electron/electron/blob/master/docs/api/web-contents.md#contentssendinputeventevent - Details about how to create input event objects: https://github.com/electron/electron/blob/master/docs/api/web-contents.md#contentssendinputeventevent
Example `shortcuts.json` for `https://deezer.com` & `https://soundcloud.com` to get your play/pause/previous/next media keys working: Example `shortcuts.json` for `https://deezer.com` & `https://soundcloud.com` to get your play/pause/previous/next media keys working:
```json ```json
[ [
{ {
@ -699,16 +706,12 @@ Example `shortcuts.json` for `https://deezer.com` & `https://soundcloud.com` to
{ {
"type": "keyDown", "type": "keyDown",
"keyCode": "Left", "keyCode": "Left",
"modifiers": [ "modifiers": ["shift"]
"shift"
]
}, },
{ {
"type": "keyUp", "type": "keyUp",
"keyCode": "Left", "keyCode": "Left",
"modifiers": [ "modifiers": ["shift"]
"shift"
]
}, },
{ {
"type": "keyUp", "type": "keyUp",
@ -726,16 +729,12 @@ Example `shortcuts.json` for `https://deezer.com` & `https://soundcloud.com` to
{ {
"type": "keyDown", "type": "keyDown",
"keyCode": "Right", "keyCode": "Right",
"modifiers": [ "modifiers": ["shift"]
"shift"
]
}, },
{ {
"type": "keyUp", "type": "keyUp",
"keyCode": "Right", "keyCode": "Right",
"modifiers": [ "modifiers": ["shift"]
"shift"
]
}, },
{ {
"type": "keyUp", "type": "keyUp",
@ -793,46 +792,46 @@ var nativefier = require('nativefier').default;
// possible options, defaults unless specified otherwise // possible options, defaults unless specified otherwise
var options = { var options = {
name: 'Web WhatsApp', // will be inferred if not specified name: 'Web WhatsApp', // will be inferred if not specified
targetUrl: 'http://web.whatsapp.com', // required targetUrl: 'http://web.whatsapp.com', // required
platform: 'darwin', // defaults to the current system platform: 'darwin', // defaults to the current system
arch: 'x64', // defaults to the current system arch: 'x64', // defaults to the current system
version: '0.36.4', version: '0.36.4',
out: '.', out: '.',
overwrite: false, overwrite: false,
asar: false, // see conceal asar: false, // see conceal
icon: '~/Desktop/icon.png', icon: '~/Desktop/icon.png',
counter: false, counter: false,
bounce: false, bounce: false,
width: 1280, width: 1280,
height: 800, height: 800,
showMenuBar: false, showMenuBar: false,
fastQuit: false, fastQuit: false,
userAgent: 'Mozilla ...', // will infer a default for your current system userAgent: 'Mozilla ...', // will infer a default for your current system
ignoreCertificate: false, ignoreCertificate: false,
ignoreGpuBlacklist: false, ignoreGpuBlacklist: false,
enableEs3Apis: false, enableEs3Apis: false,
internalUrls: '.*?', // defaults to URLs on same second-level domain as app internalUrls: '.*?', // defaults to URLs on same second-level domain as app
blockExternalUrls: false, blockExternalUrls: false,
insecure: false, insecure: false,
honest: false, honest: false,
zoom: 1.0, zoom: 1.0,
singleInstance: false, singleInstance: false,
clearCache: false, clearCache: false,
fileDownloadOptions: { fileDownloadOptions: {
saveAs: true // always show "Save As" dialog saveAs: true, // always show "Save As" dialog
}, },
processEnvs: { processEnvs: {
"GOOGLE_API_KEY": "<your-google-api-key>" GOOGLE_API_KEY: '<your-google-api-key>',
} },
}; };
nativefier(options, function(error, appPath) { nativefier(options, function (error, appPath) {
if (error) { if (error) {
console.error(error); console.error(error);
return; return;
} }
console.log('App has been nativefied to', appPath); console.log('App has been nativefied to', appPath);
}); });
``` ```
@ -840,7 +839,7 @@ nativefier(options, function(error, appPath) {
#### [version-string] #### [version-string]
*Object* (**deprecated** as removed in `electron-packager` 9.0.0, please use the _Object_ (**deprecated** as removed in `electron-packager` 9.0.0, please use the
[`win32metadata`](#win32metadata) parameter instead) [`win32metadata`](#win32metadata) parameter instead)
#### [win32metadata] #### [win32metadata]
@ -857,11 +856,18 @@ Example:
nativefier <your-geolocation-enabled-website> --win32metadata '{"ProductName": "Your Product Name", "InternalName", "Your Internal Name", "FileDescription": "Your File Description"}' nativefier <your-geolocation-enabled-website> --win32metadata '{"ProductName": "Your Product Name", "InternalName", "Your Internal Name", "FileDescription": "Your File Description"}'
``` ```
#### [disable-old-build-warning-yesiknowitisinsecure]
Disables the warning shown when opening a Nativefier app made a long time ago, using an old and probably insecure Electron. Nativefier uses the Chrome browser (through Electron), and remaining on an old version is A. performance sub-optimal and B. dangerous.
However, there are legitimate use cases to disable such a warning. For example, if you are using Nativefier to ship a kiosk app exposing an internal site (over which you have control). Under those circumstances, it is reasonable to disable this warning that you definitely don't want end-users to see.
##### Programmatic API ##### Programmatic API
*Object* _Object_
Object (also known as a "hash") of application metadata to embed into the executable: Object (also known as a "hash") of application metadata to embed into the executable:
- `CompanyName` - `CompanyName`
- `FileDescription` - `FileDescription`
- `OriginalFilename` - `OriginalFilename`

View File

@ -64,9 +64,11 @@ function pickElectronAppArgs(options: AppOptions): any {
versionString: options.nativefier.versionString, versionString: options.nativefier.versionString,
width: options.nativefier.width, width: options.nativefier.width,
win32metadata: options.packager.win32metadata, win32metadata: options.packager.win32metadata,
disableOldBuildWarning: options.nativefier.disableOldBuildWarning,
x: options.nativefier.x, x: options.nativefier.x,
y: options.nativefier.y, y: options.nativefier.y,
zoom: options.nativefier.zoom, zoom: options.nativefier.zoom,
buildDate: new Date().getTime(),
}; };
} }

View File

@ -283,6 +283,10 @@ if (require.main === module) {
'--background-color <value>', '--background-color <value>',
"sets the app background color, for better integration while the app is loading. Example value: '#2e2c29'", "sets the app background color, for better integration while the app is loading. Example value: '#2e2c29'",
) )
.option(
'--disable-old-build-warning-yesiknowitisinsecure',
'Disables warning when opening an app made with an old version of Nativefier. Nativefier uses the Chrome browser (through Electron), and it is dangerous to keep using an old version of it.)',
)
.option( .option(
'--darwin-dark-mode-support', '--darwin-dark-mode-support',
'(macOS only) enable Dark Mode support on macOS 10.14+', '(macOS only) enable Dark Mode support on macOS 10.14+',

View File

@ -20,6 +20,7 @@ export interface AppOptions {
disableContextMenu: boolean; disableContextMenu: boolean;
disableDevTools: boolean; disableDevTools: boolean;
disableGpu: boolean; disableGpu: boolean;
disableOldBuildWarning: boolean;
diskCacheSize: number; diskCacheSize: number;
enableEs3Apis: boolean; enableEs3Apis: boolean;
fastQuit: boolean; fastQuit: boolean;

View File

@ -60,6 +60,8 @@ export async function getOptions(rawOptions: any): Promise<AppOptions> {
disableDevTools: rawOptions.disableDevTools, disableDevTools: rawOptions.disableDevTools,
disableGpu: rawOptions.disableGpu || false, disableGpu: rawOptions.disableGpu || false,
diskCacheSize: rawOptions.diskCacheSize || null, diskCacheSize: rawOptions.diskCacheSize || null,
disableOldBuildWarning:
rawOptions.disableOldBuildWarningYesiknowitisinsecure || false,
enableEs3Apis: rawOptions.enableEs3Apis || false, enableEs3Apis: rawOptions.enableEs3Apis || false,
fastQuit: rawOptions.fastQuit || false, fastQuit: rawOptions.fastQuit || false,
fileDownloadOptions: rawOptions.fileDownloadOptions, fileDownloadOptions: rawOptions.fileDownloadOptions,