@electron-forge/plugin-fuses 6.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md ADDED
@@ -0,0 +1,34 @@
1
+ @electron-forge/plugin-fuses
2
+ =====
3
+
4
+ This plugin allows flipping [Electron Fuses](https://github.com/electron/fuses) when packaging your app with Electron Forge.
5
+
6
+ ## Usage
7
+
8
+ Install `@electron-forge/plugin-fuses` and `@electron/fuses` as dev dependencies and add this plugin to the `plugins` array in your Forge configuration:
9
+ ```shell
10
+ # Yarn
11
+ yarn add --dev @electron-forge/plugin-fuses @electron/fuses
12
+
13
+ # npm
14
+ npm i -D @electron-forge/plugin-fuses @electron/fuses
15
+ ```
16
+
17
+ ```js
18
+ // forge.config.js
19
+
20
+ const { FusesPlugin } = require('@electron-forge/plugin-fuses');
21
+ const { FuseV1Options, FuseVersion } = require('@electron/fuses');
22
+
23
+ const forgeConfig = {
24
+ plugins: [
25
+ new FusesPlugin({
26
+ version: FuseVersion.V1,
27
+ [FuseV1Options.RunAsNode]: false,
28
+ // ...any other options supported by @electron/fuses
29
+ }),
30
+ ],
31
+ };
32
+
33
+ module.exports = forgeConfig;
34
+ ```
@@ -0,0 +1,11 @@
1
+ import { PluginBase } from '@electron-forge/plugin-base';
2
+ import { ForgeMultiHookMap } from '@electron-forge/shared-types';
3
+ import { FuseConfig } from '@electron/fuses';
4
+ export default class FusesPlugin extends PluginBase<FuseConfig> {
5
+ name: string;
6
+ fusesConfig: FuseConfig<boolean>;
7
+ constructor(fusesConfig: FuseConfig);
8
+ getHooks(): ForgeMultiHookMap;
9
+ }
10
+ export { FusesPlugin };
11
+ //# sourceMappingURL=FusesPlugin.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FusesPlugin.d.ts","sourceRoot":"","sources":["../src/FusesPlugin.ts"],"names":[],"mappings":"AAEA,OAAO,EAAuB,UAAU,EAAE,MAAM,6BAA6B,CAAC;AAC9E,OAAO,EAAE,iBAAiB,EAAiB,MAAM,8BAA8B,CAAC;AAChF,OAAO,EAAa,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAIxD,MAAM,CAAC,OAAO,OAAO,WAAY,SAAQ,UAAU,CAAC,UAAU,CAAC;IAC7D,IAAI,SAAW;IAEf,WAAW,sBAAoB;gBAEnB,WAAW,EAAE,UAAU;IAMnC,QAAQ,IAAI,iBAAiB;CAyB9B;AAED,OAAO,EAAE,WAAW,EAAE,CAAC"}
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.FusesPlugin = void 0;
7
+ const path_1 = __importDefault(require("path"));
8
+ const plugin_base_1 = require("@electron-forge/plugin-base");
9
+ const fuses_1 = require("@electron/fuses");
10
+ const getElectronExecutablePath_1 = require("./util/getElectronExecutablePath");
11
+ class FusesPlugin extends plugin_base_1.PluginBase {
12
+ constructor(fusesConfig) {
13
+ super(fusesConfig);
14
+ this.name = 'fuses';
15
+ this.fusesConfig = {};
16
+ this.fusesConfig = fusesConfig;
17
+ }
18
+ getHooks() {
19
+ return {
20
+ packageAfterCopy: (0, plugin_base_1.namedHookWithTaskFn)(async (listrTask, resolvedForgeConfig, resourcesPath, electronVersion, platform, arch) => {
21
+ const { fusesConfig } = this;
22
+ const applePlatforms = ['darwin', 'mas'];
23
+ if (Object.keys(fusesConfig).length) {
24
+ const pathToElectronExecutable = (0, getElectronExecutablePath_1.getElectronExecutablePath)({
25
+ appName: applePlatforms.includes(platform) ? 'Electron' : 'electron',
26
+ basePath: path_1.default.resolve(resourcesPath, '../..'),
27
+ platform,
28
+ });
29
+ const osxSignConfig = resolvedForgeConfig.packagerConfig.osxSign;
30
+ const hasOSXSignConfig = (typeof osxSignConfig === 'object' && Boolean(Object.keys(osxSignConfig).length)) || Boolean(osxSignConfig);
31
+ await (0, fuses_1.flipFuses)(pathToElectronExecutable, {
32
+ resetAdHocDarwinSignature: !hasOSXSignConfig && applePlatforms.includes(platform) && arch === 'arm64',
33
+ ...this.fusesConfig,
34
+ });
35
+ }
36
+ }, 'Flipping Fuses'),
37
+ };
38
+ }
39
+ }
40
+ exports.default = FusesPlugin;
41
+ exports.FusesPlugin = FusesPlugin;
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRnVzZXNQbHVnaW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvRnVzZXNQbHVnaW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsZ0RBQXdCO0FBRXhCLDZEQUE4RTtBQUU5RSwyQ0FBd0Q7QUFFeEQsZ0ZBQTZFO0FBRTdFLE1BQXFCLFdBQVksU0FBUSx3QkFBc0I7SUFLN0QsWUFBWSxXQUF1QjtRQUNqQyxLQUFLLENBQUMsV0FBVyxDQUFDLENBQUM7UUFMckIsU0FBSSxHQUFHLE9BQU8sQ0FBQztRQUVmLGdCQUFXLEdBQUcsRUFBZ0IsQ0FBQztRQUs3QixJQUFJLENBQUMsV0FBVyxHQUFHLFdBQVcsQ0FBQztJQUNqQyxDQUFDO0lBRUQsUUFBUTtRQUNOLE9BQU87WUFDTCxnQkFBZ0IsRUFBRSxJQUFBLGlDQUFtQixFQUFxQixLQUFLLEVBQUUsU0FBUyxFQUFFLG1CQUFtQixFQUFFLGFBQWEsRUFBRSxlQUFlLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxFQUFFO2dCQUNqSixNQUFNLEVBQUUsV0FBVyxFQUFFLEdBQUcsSUFBSSxDQUFDO2dCQUU3QixNQUFNLGNBQWMsR0FBb0IsQ0FBQyxRQUFRLEVBQUUsS0FBSyxDQUFDLENBQUM7Z0JBRTFELElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxNQUFNLEVBQUU7b0JBQ25DLE1BQU0sd0JBQXdCLEdBQUcsSUFBQSxxREFBeUIsRUFBQzt3QkFDekQsT0FBTyxFQUFFLGNBQWMsQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsVUFBVTt3QkFDcEUsUUFBUSxFQUFFLGNBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxFQUFFLE9BQU8sQ0FBQzt3QkFDOUMsUUFBUTtxQkFDVCxDQUFDLENBQUM7b0JBRUgsTUFBTSxhQUFhLEdBQUcsbUJBQW1CLENBQUMsY0FBYyxDQUFDLE9BQU8sQ0FBQztvQkFDakUsTUFBTSxnQkFBZ0IsR0FBRyxDQUFDLE9BQU8sYUFBYSxLQUFLLFFBQVEsSUFBSSxPQUFPLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxJQUFJLE9BQU8sQ0FBQyxhQUFhLENBQUMsQ0FBQztvQkFFckksTUFBTSxJQUFBLGlCQUFTLEVBQUMsd0JBQXdCLEVBQUU7d0JBQ3hDLHlCQUF5QixFQUFFLENBQUMsZ0JBQWdCLElBQUksY0FBYyxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsSUFBSSxJQUFJLEtBQUssT0FBTzt3QkFDckcsR0FBRyxJQUFJLENBQUMsV0FBVztxQkFDcEIsQ0FBQyxDQUFDO2lCQUNKO1lBQ0gsQ0FBQyxFQUFFLGdCQUFnQixDQUFDO1NBQ3JCLENBQUM7SUFDSixDQUFDO0NBQ0Y7QUFwQ0QsOEJBb0NDO0FBRVEsa0NBQVcifQ==
@@ -0,0 +1,9 @@
1
+ import { ForgePlatform } from '@electron-forge/shared-types';
2
+ declare type GetElectronExecutablePathParams = {
3
+ appName: string;
4
+ basePath: string;
5
+ platform: ForgePlatform;
6
+ };
7
+ export declare function getElectronExecutablePath({ appName, basePath, platform }: GetElectronExecutablePathParams): string;
8
+ export {};
9
+ //# sourceMappingURL=getElectronExecutablePath.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getElectronExecutablePath.d.ts","sourceRoot":"","sources":["../../src/util/getElectronExecutablePath.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAE7D,aAAK,+BAA+B,GAAG;IACrC,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,aAAa,CAAC;CACzB,CAAC;AAEF,wBAAgB,yBAAyB,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,EAAE,+BAA+B,GAAG,MAAM,CAKlH"}
@@ -0,0 +1,12 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.getElectronExecutablePath = void 0;
7
+ const path_1 = __importDefault(require("path"));
8
+ function getElectronExecutablePath({ appName, basePath, platform }) {
9
+ return path_1.default.join(basePath, ['darwin', 'mas'].includes(platform) ? path_1.default.join('MacOS', appName) : [appName, process.platform === 'win32' ? '.exe' : ''].join(''));
10
+ }
11
+ exports.getElectronExecutablePath = getElectronExecutablePath;
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0RWxlY3Ryb25FeGVjdXRhYmxlUGF0aC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsL2dldEVsZWN0cm9uRXhlY3V0YWJsZVBhdGgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsZ0RBQXdCO0FBVXhCLFNBQWdCLHlCQUF5QixDQUFDLEVBQUUsT0FBTyxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQW1DO0lBQ3hHLE9BQU8sY0FBSSxDQUFDLElBQUksQ0FDZCxRQUFRLEVBQ1IsQ0FBQyxRQUFRLEVBQUUsS0FBSyxDQUFDLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxjQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLEVBQUUsT0FBTyxDQUFDLFFBQVEsS0FBSyxPQUFPLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUNwSSxDQUFDO0FBQ0osQ0FBQztBQUxELDhEQUtDIn0=
package/package.json ADDED
@@ -0,0 +1,39 @@
1
+ {
2
+ "name": "@electron-forge/plugin-fuses",
3
+ "version": "6.1.0",
4
+ "description": "A plugin for flipping Electron Fuses in Electron Forge",
5
+ "repository": "https://github.com/electron/forge",
6
+ "author": "Erik Moura <erikian@erikian.dev>",
7
+ "license": "MIT",
8
+ "main": "dist/FusesPlugin.js",
9
+ "files": [
10
+ "dist",
11
+ "package.json",
12
+ "README.md"
13
+ ],
14
+ "typings": "dist/FusesPlugin.d.ts",
15
+ "scripts": {
16
+ "test": "xvfb-maybe mocha --config ../../../.mocharc.js test/**/*_spec*.ts"
17
+ },
18
+ "devDependencies": {
19
+ "@electron/fuses": ">=1.0.0",
20
+ "@malept/cross-spawn-promise": "^2.0.0",
21
+ "chai": "^4.3.3",
22
+ "fs-extra": "^10.0.0",
23
+ "mocha": "^9.0.1",
24
+ "xvfb-maybe": "^0.2.1"
25
+ },
26
+ "peerDependencies": {
27
+ "@electron/fuses": ">=1.0.0"
28
+ },
29
+ "engines": {
30
+ "node": ">= 14.17.5"
31
+ },
32
+ "dependencies": {
33
+ "@electron-forge/plugin-base": "6.1.0",
34
+ "@electron-forge/shared-types": "6.1.0"
35
+ },
36
+ "publishConfig": {
37
+ "access": "public"
38
+ }
39
+ }