172 lines
16 KiB
JavaScript
172 lines
16 KiB
JavaScript
"use strict";
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
value: true
|
|
});
|
|
exports.default = void 0;
|
|
|
|
require("source-map-support/register");
|
|
|
|
var _fsExtra = _interopRequireDefault(require("fs-extra"));
|
|
|
|
var _path = _interopRequireDefault(require("path"));
|
|
|
|
var _which = _interopRequireDefault(require("which"));
|
|
|
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
|
|
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
|
|
class Maker {
|
|
constructor(configFetcher = {}, providedPlatforms) {
|
|
this.configFetcher = configFetcher;
|
|
this.providedPlatforms = providedPlatforms;
|
|
|
|
_defineProperty(this, "config", void 0);
|
|
|
|
_defineProperty(this, "name", void 0);
|
|
|
|
_defineProperty(this, "defaultPlatforms", void 0);
|
|
|
|
_defineProperty(this, "requiredExternalBinaries", []);
|
|
|
|
_defineProperty(this, "__isElectronForgeMaker", void 0);
|
|
|
|
Object.defineProperty(this, '__isElectronForgeMaker', {
|
|
value: true,
|
|
enumerable: false,
|
|
configurable: false
|
|
});
|
|
}
|
|
|
|
get platforms() {
|
|
if (this.providedPlatforms) return this.providedPlatforms;
|
|
return this.defaultPlatforms;
|
|
} // TODO: Remove this, it is an eye-sore and is a nasty hack to provide forge
|
|
// v5 style functionality in the new API
|
|
|
|
|
|
prepareConfig(targetArch) {
|
|
if (typeof this.configFetcher === 'function') {
|
|
this.config = this.configFetcher(targetArch);
|
|
} else {
|
|
this.config = this.configFetcher;
|
|
}
|
|
}
|
|
/**
|
|
* Makers must implement this method and return true or false indicating whether
|
|
* this maker can be run on the current platform. Normally this is just a process.platform
|
|
* check but it can be a deeper check for dependencies like fake-root or other
|
|
* required external build tools.
|
|
*
|
|
* If the issue is a missing dependency you should log out a HELPFUL error message
|
|
* telling the developer exactly what is missing and if possible how to get it.
|
|
*/
|
|
|
|
|
|
isSupportedOnCurrentPlatform() {
|
|
if (this.isSupportedOnCurrentPlatform === Maker.prototype.isSupportedOnCurrentPlatform) {
|
|
throw new Error(`Maker ${this.name} did not implement the isSupportedOnCurrentPlatform method`);
|
|
}
|
|
|
|
return true;
|
|
}
|
|
/**
|
|
* Makers must implement this method and return an array of absolute paths
|
|
* to the artifacts generated by your maker
|
|
*/
|
|
|
|
|
|
async make(opts) {
|
|
// eslint-disable-line max-len, @typescript-eslint/no-unused-vars
|
|
if (this.make === Maker.prototype.make) {
|
|
throw new Error(`Maker ${this.name} did not implement the make method`);
|
|
}
|
|
|
|
return [];
|
|
}
|
|
/**
|
|
* Helpers
|
|
*/
|
|
|
|
/**
|
|
* Ensures the directory exists and is forced to be empty.
|
|
*
|
|
* I.e. If the directory already exists it is deleted and recreated, this
|
|
* is a destructive operation
|
|
*/
|
|
|
|
|
|
async ensureDirectory(dir) {
|
|
if (await _fsExtra.default.pathExists(dir)) {
|
|
await _fsExtra.default.remove(dir);
|
|
}
|
|
|
|
return _fsExtra.default.mkdirs(dir);
|
|
}
|
|
/**
|
|
* Ensures the path to the file exists and the file does not exist
|
|
*
|
|
* I.e. If the file already exists it is deleted and the path created
|
|
*/
|
|
|
|
|
|
async ensureFile(file) {
|
|
if (await _fsExtra.default.pathExists(file)) {
|
|
await _fsExtra.default.remove(file);
|
|
}
|
|
|
|
await _fsExtra.default.mkdirs(_path.default.dirname(file));
|
|
}
|
|
/**
|
|
* Checks if the specified binaries exist, which are required for the maker to be used.
|
|
*/
|
|
|
|
|
|
externalBinariesExist() {
|
|
return this.requiredExternalBinaries.every(binary => _which.default.sync(binary, {
|
|
nothrow: true
|
|
}) !== null);
|
|
}
|
|
/**
|
|
* Throws an error if any of the binaries don't exist.
|
|
*/
|
|
|
|
|
|
ensureExternalBinariesExist() {
|
|
if (!this.externalBinariesExist()) {
|
|
throw new Error(`Cannot make for ${this.name}, the following external binaries need to be installed: ${this.requiredExternalBinaries.join(', ')}`);
|
|
}
|
|
}
|
|
/**
|
|
* Checks if the given module is installed, used for testing if optional dependencies
|
|
* are installed or not
|
|
*/
|
|
|
|
|
|
isInstalled(module) {
|
|
try {
|
|
// eslint-disable-next-line global-require, import/no-dynamic-require
|
|
require(module);
|
|
|
|
return true;
|
|
} catch (e) {
|
|
// Package doesn't exist -- must not be installable on this platform
|
|
return false;
|
|
}
|
|
}
|
|
/**
|
|
* Normalize the given semver-formatted version to a 4-part dot delimited version number without
|
|
* prerelease information for use in Windows apps.
|
|
*/
|
|
|
|
|
|
normalizeWindowsVersion(version) {
|
|
const noPrerelease = version.replace(/-.*/, '');
|
|
return `${noPrerelease}.0`;
|
|
}
|
|
|
|
}
|
|
|
|
exports.default = Maker;
|
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/Maker.ts"],"names":["Maker","constructor","configFetcher","providedPlatforms","Object","defineProperty","value","enumerable","configurable","platforms","defaultPlatforms","prepareConfig","targetArch","config","isSupportedOnCurrentPlatform","prototype","Error","name","make","opts","ensureDirectory","dir","fs","pathExists","remove","mkdirs","ensureFile","file","path","dirname","externalBinariesExist","requiredExternalBinaries","every","binary","which","sync","nothrow","ensureExternalBinariesExist","join","isInstalled","module","require","e","normalizeWindowsVersion","version","noPrerelease","replace"],"mappings":"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","sourcesContent":["import {\n  ForgeArch, ForgeConfig, ForgePlatform, IForgeMaker,\n} from '@electron-forge/shared-types';\nimport fs from 'fs-extra';\nimport path from 'path';\nimport which from 'which';\n\nexport interface MakerOptions {\n  /**\n   * The directory containing the packaged Electron application\n   */\n  dir: string;\n  /**\n   * The directory you should put all your artifacts in (potentially in sub folders)\n   * NOTE: this directory is not guarunteed to already exist\n   */\n  makeDir: string;\n  /**\n   * The resolved human friendly name of the project\n   */\n  appName: string;\n  /**\n   * The target platform you should make for\n   */\n  targetPlatform: ForgePlatform;\n  /**\n   * The target architecture you should make for\n   */\n  targetArch: ForgeArch;\n  /**\n   * Fully resolved forge configuration, you shouldn't really need this\n   */\n  forgeConfig: ForgeConfig;\n  /**\n   * The applications package.json file\n   */\n  packageJSON: any;\n}\n\nexport default abstract class Maker<C> implements IForgeMaker {\n  public config!: C;\n\n  public abstract name: string;\n\n  public abstract defaultPlatforms: ForgePlatform[];\n\n  public requiredExternalBinaries: string[] = [];\n\n  __isElectronForgeMaker!: true;\n\n  constructor(\n    private configFetcher: (C | ((arch: ForgeArch) => C)) = {} as C,\n    protected providedPlatforms?: ForgePlatform[],\n  ) {\n    Object.defineProperty(this, '__isElectronForgeMaker', {\n      value: true,\n      enumerable: false,\n      configurable: false,\n    });\n  }\n\n  get platforms() {\n    if (this.providedPlatforms) return this.providedPlatforms;\n    return this.defaultPlatforms;\n  }\n\n  // TODO: Remove this, it is an eye-sore and is a nasty hack to provide forge\n  //       v5 style functionality in the new API\n  prepareConfig(targetArch: ForgeArch) {\n    if (typeof this.configFetcher === 'function') {\n      this.config = (this.configFetcher as any as ((arch: ForgeArch) => C))(targetArch);\n    } else {\n      this.config = this.configFetcher as C;\n    }\n  }\n\n  /**\n   * Makers must implement this method and return true or false indicating whether\n   * this maker can be run on the current platform.  Normally this is just a process.platform\n   * check but it can be a deeper check for dependencies like fake-root or other\n   * required external build tools.\n   *\n   * If the issue is a missing dependency you should log out a HELPFUL error message\n   * telling the developer exactly what is missing and if possible how to get it.\n   */\n  isSupportedOnCurrentPlatform(): boolean {\n    if (this.isSupportedOnCurrentPlatform === Maker.prototype.isSupportedOnCurrentPlatform) {\n      throw new Error(`Maker ${this.name} did not implement the isSupportedOnCurrentPlatform method`);\n    }\n    return true;\n  }\n\n  /**\n   * Makers must implement this method and return an array of absolute paths\n   * to the artifacts generated by your maker\n   */\n  async make(opts: MakerOptions): Promise<string[]> { // eslint-disable-line max-len, @typescript-eslint/no-unused-vars\n    if (this.make === Maker.prototype.make) {\n      throw new Error(`Maker ${this.name} did not implement the make method`);\n    }\n    return [];\n  }\n\n  /**\n   * Helpers\n   */\n\n  /**\n   * Ensures the directory exists and is forced to be empty.\n   *\n   * I.e. If the directory already exists it is deleted and recreated, this\n   * is a destructive operation\n   */\n  async ensureDirectory(dir: string): Promise<void> {\n    if (await fs.pathExists(dir)) {\n      await fs.remove(dir);\n    }\n    return fs.mkdirs(dir);\n  }\n\n  /**\n   * Ensures the path to the file exists and the file does not exist\n   *\n   * I.e. If the file already exists it is deleted and the path created\n   */\n  async ensureFile(file: string): Promise<void> {\n    if (await fs.pathExists(file)) {\n      await fs.remove(file);\n    }\n    await fs.mkdirs(path.dirname(file));\n  }\n\n  /**\n   * Checks if the specified binaries exist, which are required for the maker to be used.\n   */\n  externalBinariesExist(): boolean {\n    return this.requiredExternalBinaries.every(\n      (binary) => which.sync(binary, { nothrow: true }) !== null,\n    );\n  }\n\n  /**\n   * Throws an error if any of the binaries don't exist.\n   */\n  ensureExternalBinariesExist() {\n    if (!this.externalBinariesExist()) {\n      throw new Error(`Cannot make for ${this.name}, the following external binaries need to be installed: ${this.requiredExternalBinaries.join(', ')}`);\n    }\n  }\n\n  /**\n   * Checks if the given module is installed, used for testing if optional dependencies\n   * are installed or not\n   */\n  isInstalled(module: string): boolean {\n    try {\n      // eslint-disable-next-line global-require, import/no-dynamic-require\n      require(module);\n      return true;\n    } catch (e) {\n      // Package doesn't exist -- must not be installable on this platform\n      return false;\n    }\n  }\n\n  /**\n   * Normalize the given semver-formatted version to a 4-part dot delimited version number without\n   * prerelease information for use in Windows apps.\n   */\n  normalizeWindowsVersion(version: string): string {\n    const noPrerelease = version.replace(/-.*/, '');\n    return `${noPrerelease}.0`;\n  }\n}\n"]}
|