@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 +34 -0
- package/dist/FusesPlugin.d.ts +11 -0
- package/dist/FusesPlugin.d.ts.map +1 -0
- package/dist/FusesPlugin.js +42 -0
- package/dist/util/getElectronExecutablePath.d.ts +9 -0
- package/dist/util/getElectronExecutablePath.d.ts.map +1 -0
- package/dist/util/getElectronExecutablePath.js +12 -0
- package/package.json +39 -0
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
|
+
}
|