UNPKG

electron-builder-lib

Version:
300 lines (259 loc) 15.4 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); var _bluebirdLst; function _load_bluebirdLst() { return _bluebirdLst = require("bluebird-lst"); } var _bluebirdLst2; function _load_bluebirdLst2() { return _bluebirdLst2 = _interopRequireDefault(require("bluebird-lst")); } var _builderUtil; function _load_builderUtil() { return _builderUtil = require("builder-util"); } var _builderUtilRuntime; function _load_builderUtilRuntime() { return _builderUtilRuntime = require("builder-util-runtime"); } var _binDownload; function _load_binDownload() { return _binDownload = require("builder-util/out/binDownload"); } var _fs; function _load_fs() { return _fs = require("builder-util/out/fs"); } var _ejs; function _load_ejs() { return _ejs = _interopRequireWildcard(require("ejs")); } var _fsExtraP; function _load_fsExtraP() { return _fsExtraP = require("fs-extra-p"); } var _lazyVal; function _load_lazyVal() { return _lazyVal = require("lazy-val"); } var _path = _interopRequireWildcard(require("path")); var _deepAssign; function _load_deepAssign() { return _deepAssign = require("read-config-file/out/deepAssign"); } var _core; function _load_core() { return _core = require("../core"); } var _CommonWindowsInstallerConfiguration; function _load_CommonWindowsInstallerConfiguration() { return _CommonWindowsInstallerConfiguration = require("../options/CommonWindowsInstallerConfiguration"); } var _pathManager; function _load_pathManager() { return _pathManager = require("../util/pathManager"); } var _vm; function _load_vm() { return _vm = require("../vm/vm"); } var _WineVm; function _load_WineVm() { return _WineVm = require("../vm/WineVm"); } var _targetUtil; function _load_targetUtil() { return _targetUtil = require("./targetUtil"); } function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } const ELECTRON_BUILDER_UPGRADE_CODE_NS_UUID = (_builderUtilRuntime || _load_builderUtilRuntime()).UUID.parse("d752fe43-5d44-44d5-9fc9-6dd1bf19d5cc"); const ROOT_DIR_ID = "APPLICATIONFOLDER"; const ASSISTED_UI_FILE_NAME = "WixUI_Assisted.wxs"; const projectTemplate = new (_lazyVal || _load_lazyVal()).Lazy((0, (_bluebirdLst || _load_bluebirdLst()).coroutine)(function* () { const template = (yield (0, (_fsExtraP || _load_fsExtraP()).readFile)(_path.join((0, (_pathManager || _load_pathManager()).getTemplatePath)("msi"), "template.xml"), "utf8")).replace(/{{/g, "<%").replace(/}}/g, "%>").replace(/\${([^}]+)}/g, "<%=$1%>"); return (_ejs || _load_ejs()).compile(template); })); // WiX doesn't support Mono, so, dontnet462 is required to be installed for wine (preinstalled in our bundled wine) class MsiTarget extends (_core || _load_core()).Target { constructor(packager, outDir) { super("msi"); this.packager = packager; this.outDir = outDir; this.vm = process.platform === "win32" ? new (_vm || _load_vm()).VmManager() : new (_WineVm || _load_WineVm()).WineVmManager(); this.options = (0, (_deepAssign || _load_deepAssign()).deepAssign)(this.packager.platformSpecificBuildOptions, this.packager.config.msi); } build(appOutDir, arch) { var _this = this; return (0, (_bluebirdLst || _load_bluebirdLst()).coroutine)(function* () { const packager = _this.packager; const artifactName = packager.expandArtifactNamePattern(_this.options, "msi", arch); const artifactPath = _path.join(_this.outDir, artifactName); _this.logBuilding("MSI", artifactPath, arch); const stageDir = yield (0, (_targetUtil || _load_targetUtil()).createStageDir)(_this, packager, arch); const vm = _this.vm; const commonOptions = (0, (_CommonWindowsInstallerConfiguration || _load_CommonWindowsInstallerConfiguration()).getEffectiveOptions)(_this.options, _this.packager); if (commonOptions.isAssisted) { // F*** *** *** *** *** *** *** *** *** *** *** *** *** WiX *** *** *** *** *** *** *** *** *** // cannot understand how to set MSIINSTALLPERUSER on radio box change. In any case installed per user. (_builderUtil || _load_builderUtil()).log.warn(`MSI DOESN'T SUPPORT assisted installer. Please use NSIS instead.`); } const projectFile = stageDir.getTempFile("project.wxs"); const objectFiles = ["project.wixobj"]; const uiFile = commonOptions.isAssisted ? stageDir.getTempFile(ASSISTED_UI_FILE_NAME) : null; yield (0, (_fsExtraP || _load_fsExtraP()).writeFile)(projectFile, (yield _this.writeManifest(appOutDir, arch, commonOptions))); if (uiFile !== null) { yield (0, (_fsExtraP || _load_fsExtraP()).writeFile)(uiFile, (yield (0, (_fsExtraP || _load_fsExtraP()).readFile)(_path.join((0, (_pathManager || _load_pathManager()).getTemplatePath)("msi"), ASSISTED_UI_FILE_NAME), "utf8"))); objectFiles.push(ASSISTED_UI_FILE_NAME.replace(".wxs", ".wixobj")); } // noinspection SpellCheckingInspection const vendorPath = yield (0, (_binDownload || _load_binDownload()).getBinFromGithub)("wix", "4.0.0.5512.2", "/X5poahdCc3199Vt6AP7gluTlT1nxi9cbbHhZhCMEu+ngyP1LiBMn+oZX7QAZVaKeBMc2SjVp7fJqNLqsUnPNQ=="); // noinspection SpellCheckingInspection const candleArgs = ["-arch", arch === (_builderUtil || _load_builderUtil()).Arch.ia32 ? "x86" : arch === (_builderUtil || _load_builderUtil()).Arch.armv7l ? "arm" : "x64", `-dappDir=${vm.toVmFile(appOutDir)}`].concat(_this.getCommonWixArgs()); candleArgs.push("project.wxs"); if (uiFile !== null) { candleArgs.push(ASSISTED_UI_FILE_NAME); } yield vm.exec(vm.toVmFile(_path.join(vendorPath, "candle.exe")), candleArgs, { cwd: stageDir.dir }); yield _this.light(objectFiles, vm, artifactPath, appOutDir, vendorPath, stageDir.dir); yield stageDir.cleanup(); yield packager.sign(artifactPath); packager.info.dispatchArtifactCreated({ file: artifactPath, packager, arch, safeArtifactName: packager.computeSafeArtifactName(artifactName, "msi"), target: _this, isWriteUpdateInfo: false }); })(); } light(objectFiles, vm, artifactPath, appOutDir, vendorPath, tempDir) { var _this2 = this; return (0, (_bluebirdLst || _load_bluebirdLst()).coroutine)(function* () { // noinspection SpellCheckingInspection const lightArgs = ["-out", vm.toVmFile(artifactPath), "-v", // https://github.com/wixtoolset/issues/issues/5169 "-spdb", // https://sourceforge.net/p/wix/bugs/2405/ // error LGHT1076 : ICE61: This product should remove only older versions of itself. The Maximum version is not less than the current product. (1.1.0.42 1.1.0.42) "-sw1076", `-dappDir=${vm.toVmFile(appOutDir)}`].concat(_this2.getCommonWixArgs()); // http://windows-installer-xml-wix-toolset.687559.n2.nabble.com/Build-3-5-2229-0-give-me-the-following-error-error-LGHT0216-An-unexpected-Win32-exception-with-errorn-td5707443.html if (process.platform !== "win32") { // noinspection SpellCheckingInspection lightArgs.push("-sval"); } if (_this2.options.oneClick === false) { lightArgs.push("-ext", "WixUIExtension"); } // objectFiles - only filenames, we set current directory to our temp stage dir lightArgs.push(...objectFiles); yield vm.exec(vm.toVmFile(_path.join(vendorPath, "light.exe")), lightArgs, { cwd: tempDir }); })(); } getCommonWixArgs() { const args = ["-pedantic"]; if (this.options.warningsAsErrors !== false) { args.push("-wx"); } return args; } writeManifest(appOutDir, arch, commonOptions) { var _this3 = this; return (0, (_bluebirdLst || _load_bluebirdLst()).coroutine)(function* () { const appInfo = _this3.packager.appInfo; const { files, dirs } = yield _this3.computeFileDeclaration(appOutDir); const companyName = appInfo.companyName; if (!companyName) { (_builderUtil || _load_builderUtil()).log.warn(`Manufacturer is not set for MSI — please set "author" in the package.json`); } const compression = _this3.packager.compression; const options = _this3.options; const iconPath = yield _this3.packager.getIconPath(); return (yield projectTemplate.value)(Object.assign({}, commonOptions, { isRunAfterFinish: options.runAfterFinish !== false, iconPath: iconPath == null ? null : _this3.vm.toVmFile(iconPath), compressionLevel: compression === "store" ? "none" : "high", version: appInfo.versionInWeirdWindowsForm, productName: appInfo.productName, upgradeCode: (options.upgradeCode || (_builderUtilRuntime || _load_builderUtilRuntime()).UUID.v5(appInfo.id, ELECTRON_BUILDER_UPGRADE_CODE_NS_UUID)).toUpperCase(), manufacturer: companyName || appInfo.productName, appDescription: appInfo.description, // https://stackoverflow.com/questions/1929038/compilation-error-ice80-the-64bitcomponent-uses-32bitdirectory programFilesId: arch === (_builderUtil || _load_builderUtil()).Arch.x64 ? "ProgramFiles64Folder" : "ProgramFilesFolder", // wix in the name because special wix format can be used in the name installationDirectoryWixName: /^[-_+0-9a-zA-Z ]+$/.test(appInfo.productFilename) ? appInfo.productFilename : appInfo.sanitizedName, dirs, files })); })(); } computeFileDeclaration(appOutDir) { var _this4 = this; return (0, (_bluebirdLst || _load_bluebirdLst()).coroutine)(function* () { const appInfo = _this4.packager.appInfo; let isRootDirAddedToRemoveTable = false; const dirNames = new Set(); const dirs = []; const fileSpace = " ".repeat(6); const commonOptions = (0, (_CommonWindowsInstallerConfiguration || _load_CommonWindowsInstallerConfiguration()).getEffectiveOptions)(_this4.options, _this4.packager); const files = yield (_bluebirdLst2 || _load_bluebirdLst2()).default.map((0, (_fs || _load_fs()).walk)(appOutDir), function (file) { const packagePath = file.substring(appOutDir.length + 1); const lastSlash = packagePath.lastIndexOf(_path.sep); const fileName = lastSlash > 0 ? packagePath.substring(lastSlash + 1) : packagePath; let directoryId = null; let dirName = ""; // Wix Directory.FileSource doesn't work - https://stackoverflow.com/questions/21519388/wix-filesource-confusion if (lastSlash > 0) { // This Name attribute may also define multiple directories using the inline directory syntax. // For example, "ProgramFilesFolder:\My Company\My Product\bin" would create a reference to a Directory element with Id="ProgramFilesFolder" then create directories named "My Company" then "My Product" then "bin" nested beneath each other. // This syntax is a shortcut to defining each directory in an individual Directory element. dirName = packagePath.substring(0, lastSlash); // add U (user) suffix just to be sure that will be not overwrite system WIX directory ids. directoryId = `${dirName.toLowerCase()}_u`; if (!dirNames.has(dirName)) { dirNames.add(dirName); dirs.push(`<Directory Id="${directoryId}" Name="${ROOT_DIR_ID}:\\${dirName}\\"/>`); } } else if (!isRootDirAddedToRemoveTable) { isRootDirAddedToRemoveTable = true; } // since RegistryValue can be part of Component, *** *** *** *** *** *** *** *** *** wix cannot auto generate guid // https://stackoverflow.com/questions/1405100/change-my-component-guid-in-wix let result = `<Component${directoryId === null ? "" : ` Directory="${directoryId}"`}>`; result += `\n${fileSpace} <File Name="${fileName}" Source="$(var.appDir)${_path.sep}${packagePath}" ReadOnly="yes" KeyPath="yes"`; const isMainExecutable = packagePath === `${appInfo.productFilename}.exe`; if (isMainExecutable) { result += ' Id="mainExecutable"'; } else if (directoryId === null) { result += ` Id="${_path.basename(packagePath)}_f"`; } if (isMainExecutable && (commonOptions.isCreateDesktopShortcut || commonOptions.isCreateStartMenuShortcut)) { result += `>\n`; const shortcutName = commonOptions.shortcutName; if (commonOptions.isCreateDesktopShortcut) { result += `${fileSpace} <Shortcut Id="desktopShortcut" Directory="DesktopFolder" Name="${shortcutName}" WorkingDirectory="APPLICATIONFOLDER" Advertise="yes" Icon="icon.ico"/>\n`; } const hasMenuCategory = commonOptions.menuCategory != null; const startMenuShortcutDirectoryId = hasMenuCategory ? "AppProgramMenuDir" : "ProgramMenuFolder"; if (commonOptions.isCreateStartMenuShortcut) { if (hasMenuCategory) { dirs.push(`<Directory Id="${startMenuShortcutDirectoryId}" Name="ProgramMenuFolder:\\${commonOptions.menuCategory}\\"/>`); } result += `${fileSpace} <Shortcut Id="startMenuShortcut" Directory="${startMenuShortcutDirectoryId}" Name="${shortcutName}" WorkingDirectory="APPLICATIONFOLDER" Advertise="yes" Icon="icon.ico"/>\n`; } result += `${fileSpace}</File>`; if (hasMenuCategory) { result += `<RemoveFolder Id="${startMenuShortcutDirectoryId}" On="uninstall"/>\n`; } } else { result += `/>`; } return `${result}\n${fileSpace}</Component>`; }); return { dirs: listToString(dirs, 2), files: listToString(files, 3) }; })(); } } exports.default = MsiTarget; function listToString(list, indentLevel) { const space = " ".repeat(indentLevel * 2); return list.join(`\n${space}`); } //# sourceMappingURL=MsiTarget.js.map