electron-forge
Version:
A complete tool for building modern Electron applications
291 lines (213 loc) • 23.9 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
var _assign = require('babel-runtime/core-js/object/assign');
var _assign2 = _interopRequireDefault(_assign);
var _keys = require('babel-runtime/core-js/object/keys');
var _keys2 = _interopRequireDefault(_keys);
var _promise = require('babel-runtime/core-js/promise');
var _promise2 = _interopRequireDefault(_promise);
var _getIterator2 = require('babel-runtime/core-js/get-iterator');
var _getIterator3 = _interopRequireDefault(_getIterator2);
var _bluebird = require('bluebird');
require('colors');
var _debug = require('debug');
var _debug2 = _interopRequireDefault(_debug);
var _nodeFetch = require('node-fetch');
var _nodeFetch2 = _interopRequireDefault(_nodeFetch);
var _fsExtra = require('fs-extra');
var _fsExtra2 = _interopRequireDefault(_fsExtra);
var _inquirer = require('inquirer');
var _inquirer2 = _interopRequireDefault(_inquirer);
var _nugget = require('nugget');
var _nugget2 = _interopRequireDefault(_nugget);
var _os = require('os');
var _os2 = _interopRequireDefault(_os);
var _path = require('path');
var _path2 = _interopRequireDefault(_path);
var _pify = require('pify');
var _pify2 = _interopRequireDefault(_pify);
var _semver = require('semver');
var _semver2 = _interopRequireDefault(_semver);
var _oraHandler = require('../util/ora-handler');
var _oraHandler2 = _interopRequireDefault(_oraHandler);
var _messages = require('../util/messages');
var _dmg = require('../installers/darwin/dmg');
var _dmg2 = _interopRequireDefault(_dmg);
var _zip = require('../installers/darwin/zip');
var _zip2 = _interopRequireDefault(_zip);
var _deb = require('../installers/linux/deb');
var _deb2 = _interopRequireDefault(_deb);
var _rpm = require('../installers/linux/rpm');
var _rpm2 = _interopRequireDefault(_rpm);
var _exe = require('../installers/win32/exe');
var _exe2 = _interopRequireDefault(_exe);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
const d = (0, _debug2.default)('electron-forge:install');
const GITHUB_API = 'https://api.github.com';
/**
* @typedef {Object} InstallOptions
* @property {boolean} [interactive=false] Whether to use sensible defaults or prompt the user visually
* @property {boolean} [prerelease=false] Whether to install prerelease versions
* @property {string} repo The GitHub repository to install from, in the format owner/name
* @property {function} chooseAsset A function that must return the asset to use/install from a provided array of compatible GitHub assets
*/
/**
* Install an Electron application from GitHub. If you leave interactive as `false`, you MUST provide a `chooseAsset` function.
*
* @param {InstallOptions} providedOptions - Options for the install method
* @return {Promise} Will resolve when the install process is complete
*/
exports.default = (() => {
var _ref = (0, _bluebird.coroutine)(function* (providedOptions = {}) {
// eslint-disable-next-line prefer-const, no-unused-vars
var _Object$assign = (0, _assign2.default)({
interactive: false,
prerelease: false
}, providedOptions);
let interactive = _Object$assign.interactive,
prerelease = _Object$assign.prerelease,
repo = _Object$assign.repo,
chooseAsset = _Object$assign.chooseAsset;
_oraHandler2.default.interactive = interactive;
let latestRelease;
let possibleAssets = [];
yield (0, _oraHandler2.default)('Searching for Application', (() => {
var _ref2 = (0, _bluebird.coroutine)(function* (searchSpinner) {
if (!repo || repo.indexOf('/') === -1) {
throw 'Invalid repository name, must be in the format owner/name';
}
d('searching for repo:', repo);
let releases;
try {
releases = yield (yield (0, _nodeFetch2.default)(`${GITHUB_API}/repos/${repo}/releases`)).json();
} catch (err) {
// Ignore error
}
if (!releases || releases.message === 'Not Found' || !Array.isArray(releases)) {
throw `Failed to find releases for repository "${repo}". Please check the name and try again.`;
}
releases = releases.filter(function (release) {
return !release.prerelease || prerelease;
});
const sortedReleases = releases.sort(function (releaseA, releaseB) {
let tagA = releaseA.tag_name;
if (tagA.substr(0, 1) === 'v') tagA = tagA.substr(1);
let tagB = releaseB.tag_name;
if (tagB.substr(0, 1) === 'v') tagB = tagB.substr(1);
return _semver2.default.gt(tagB, tagA) ? 1 : -1;
});
latestRelease = sortedReleases[0];
searchSpinner.text = 'Searching for Releases'; // eslint-disable-line
const assets = latestRelease.assets;
if (!assets || !Array.isArray(assets)) {
throw 'Could not find any assets for the latest release';
}
const installTargets = {
win32: [/\.exe$/],
darwin: [/OSX.*\.zip$/, /darwin.*\.zip$/, /macOS.*\.zip$/, /mac.*\.zip$/, /\.dmg$/],
linux: [/\.rpm$/, /\.deb$/]
};
possibleAssets = assets.filter(function (asset) {
const targetSuffixes = installTargets[process.platform];
var _iteratorNormalCompletion = true;
var _didIteratorError = false;
var _iteratorError = undefined;
try {
for (var _iterator = (0, _getIterator3.default)(targetSuffixes), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
const suffix = _step.value;
if (suffix.test(asset.name)) return true;
}
} catch (err) {
_didIteratorError = true;
_iteratorError = err;
} finally {
try {
if (!_iteratorNormalCompletion && _iterator.return) {
_iterator.return();
}
} finally {
if (_didIteratorError) {
throw _iteratorError;
}
}
}
return false;
});
if (possibleAssets.length === 0) {
throw `Failed to find any installable assets for target platform: ${`${process.platform}`.cyan}`;
}
});
return function (_x) {
return _ref2.apply(this, arguments);
};
})());
(0, _messages.info)(interactive, `Found latest release${prerelease ? ' (including prereleases)' : ''}: ${latestRelease.tag_name.cyan}`);
let targetAsset = possibleAssets[0];
if (possibleAssets.length > 1) {
if (chooseAsset) {
targetAsset = yield _promise2.default.resolve(chooseAsset(possibleAssets));
} else if (interactive) {
const choices = [];
possibleAssets.forEach(function (asset) {
choices.push({ name: asset.name, value: asset.id });
});
var _ref3 = yield _inquirer2.default.createPromptModule()({
type: 'list',
name: 'assetID',
message: 'Multiple potential assets found, please choose one from the list below:'.cyan,
choices
});
const assetID = _ref3.assetID;
targetAsset = possibleAssets.find(function (asset) {
return asset.id === assetID;
});
} else {
throw 'expected a chooseAsset function to be provided but it was not';
}
}
const tmpdir = _path2.default.resolve(_os2.default.tmpdir(), 'forge-install');
const pathSafeRepo = repo.replace(/[/\\]/g, '-');
const filename = `${pathSafeRepo}-${latestRelease.tag_name}-${targetAsset.name}`;
const fullFilePath = _path2.default.resolve(tmpdir, filename);
if (!(yield _fsExtra2.default.pathExists(fullFilePath)) || (yield _fsExtra2.default.stat(fullFilePath)).size !== targetAsset.size) {
yield _fsExtra2.default.mkdirs(tmpdir);
const nuggetOpts = {
target: filename,
dir: tmpdir,
resume: true,
strictSSL: true
};
yield (0, _pify2.default)(_nugget2.default)(targetAsset.browser_download_url, nuggetOpts);
}
yield (0, _oraHandler2.default)('Installing Application', (() => {
var _ref4 = (0, _bluebird.coroutine)(function* (installSpinner) {
const installActions = {
win32: {
'.exe': _exe2.default
},
darwin: {
'.zip': _zip2.default,
'.dmg': _dmg2.default
},
linux: {
'.deb': _deb2.default,
'.rpm': _rpm2.default
}
};
const suffixFnIdent = (0, _keys2.default)(installActions[process.platform]).find(function (suffix) {
return targetAsset.name.endsWith(suffix);
});
yield installActions[process.platform][suffixFnIdent](fullFilePath, installSpinner);
});
return function (_x2) {
return _ref4.apply(this, arguments);
};
})());
});
return function () {
return _ref.apply(this, arguments);
};
})();
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["api/install.js"],"names":["d","GITHUB_API","providedOptions","interactive","prerelease","repo","chooseAsset","asyncOra","latestRelease","possibleAssets","searchSpinner","indexOf","releases","json","err","message","Array","isArray","filter","release","sortedReleases","sort","releaseA","releaseB","tagA","tag_name","substr","tagB","semver","gt","text","assets","installTargets","win32","darwin","linux","asset","targetSuffixes","process","platform","suffix","test","name","length","cyan","targetAsset","resolve","choices","forEach","push","value","id","inquirer","createPromptModule","type","assetID","find","tmpdir","path","os","pathSafeRepo","replace","filename","fullFilePath","fs","pathExists","stat","size","mkdirs","nuggetOpts","target","dir","resume","strictSSL","nugget","browser_download_url","installSpinner","installActions","win32ExeInstaller","darwinZipInstaller","darwinDMGInstaller","linuxDebInstaller","linuxRPMInstaller","suffixFnIdent","endsWith"],"mappings":"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","file":"api/install.js","sourcesContent":["import 'colors';\nimport debug from 'debug';\nimport fetch from 'node-fetch';\nimport fs from 'fs-extra';\nimport inquirer from 'inquirer';\nimport nugget from 'nugget';\nimport os from 'os';\nimport path from 'path';\nimport pify from 'pify';\nimport semver from 'semver';\n\nimport asyncOra from '../util/ora-handler';\nimport { info } from '../util/messages';\n\nimport darwinDMGInstaller from '../installers/darwin/dmg';\nimport darwinZipInstaller from '../installers/darwin/zip';\nimport linuxDebInstaller from '../installers/linux/deb';\nimport linuxRPMInstaller from '../installers/linux/rpm';\nimport win32ExeInstaller from '../installers/win32/exe';\n\nconst d = debug('electron-forge:install');\n\nconst GITHUB_API = 'https://api.github.com';\n\n/**\n * @typedef {Object} InstallOptions\n * @property {boolean} [interactive=false] Whether to use sensible defaults or prompt the user visually\n * @property {boolean} [prerelease=false] Whether to install prerelease versions\n * @property {string} repo The GitHub repository to install from, in the format owner/name\n * @property {function} chooseAsset A function that must return the asset to use/install from a provided array of compatible GitHub assets\n */\n\n/**\n * Install an Electron application from GitHub. If you leave interactive as `false`, you MUST provide a `chooseAsset` function.\n *\n * @param {InstallOptions} providedOptions - Options for the install method\n * @return {Promise} Will resolve when the install process is complete\n */\nexport default async (providedOptions = {}) => {\n  // eslint-disable-next-line prefer-const, no-unused-vars\n  let { interactive, prerelease, repo, chooseAsset } = Object.assign({\n    interactive: false,\n    prerelease: false,\n  }, providedOptions);\n  asyncOra.interactive = interactive;\n\n  let latestRelease;\n  let possibleAssets = [];\n\n  await asyncOra('Searching for Application', async (searchSpinner) => {\n    if (!repo || repo.indexOf('/') === -1) {\n      throw 'Invalid repository name, must be in the format owner/name';\n    }\n\n    d('searching for repo:', repo);\n    let releases;\n    try {\n      releases = await (await fetch(`${GITHUB_API}/repos/${repo}/releases`)).json();\n    } catch (err) {\n      // Ignore error\n    }\n\n    if (!releases || releases.message === 'Not Found' || !Array.isArray(releases)) {\n      throw `Failed to find releases for repository \"${repo}\".  Please check the name and try again.`;\n    }\n\n    releases = releases.filter(release => !release.prerelease || prerelease);\n\n    const sortedReleases = releases.sort((releaseA, releaseB) => {\n      let tagA = releaseA.tag_name;\n      if (tagA.substr(0, 1) === 'v') tagA = tagA.substr(1);\n      let tagB = releaseB.tag_name;\n      if (tagB.substr(0, 1) === 'v') tagB = tagB.substr(1);\n      return (semver.gt(tagB, tagA) ? 1 : -1);\n    });\n    latestRelease = sortedReleases[0];\n\n    searchSpinner.text = 'Searching for Releases'; // eslint-disable-line\n\n    const assets = latestRelease.assets;\n    if (!assets || !Array.isArray(assets)) {\n      throw 'Could not find any assets for the latest release';\n    }\n\n    const installTargets = {\n      win32: [/\\.exe$/],\n      darwin: [/OSX.*\\.zip$/, /darwin.*\\.zip$/, /macOS.*\\.zip$/, /mac.*\\.zip$/, /\\.dmg$/],\n      linux: [/\\.rpm$/, /\\.deb$/],\n    };\n\n    possibleAssets = assets.filter((asset) => {\n      const targetSuffixes = installTargets[process.platform];\n      for (const suffix of targetSuffixes) {\n        if (suffix.test(asset.name)) return true;\n      }\n      return false;\n    });\n\n    if (possibleAssets.length === 0) {\n      throw `Failed to find any installable assets for target platform: ${`${process.platform}`.cyan}`;\n    }\n  });\n\n  info(interactive, `Found latest release${prerelease ? ' (including prereleases)' : ''}: ${latestRelease.tag_name.cyan}`);\n\n  let targetAsset = possibleAssets[0];\n  if (possibleAssets.length > 1) {\n    if (chooseAsset) {\n      targetAsset = await Promise.resolve(chooseAsset(possibleAssets));\n    } else if (interactive) {\n      const choices = [];\n      possibleAssets.forEach((asset) => {\n        choices.push({ name: asset.name, value: asset.id });\n      });\n      const { assetID } = await inquirer.createPromptModule()({\n        type: 'list',\n        name: 'assetID',\n        message: 'Multiple potential assets found, please choose one from the list below:'.cyan,\n        choices,\n      });\n\n      targetAsset = possibleAssets.find(asset => asset.id === assetID);\n    } else {\n      throw 'expected a chooseAsset function to be provided but it was not';\n    }\n  }\n\n  const tmpdir = path.resolve(os.tmpdir(), 'forge-install');\n  const pathSafeRepo = repo.replace(/[/\\\\]/g, '-');\n  const filename = `${pathSafeRepo}-${latestRelease.tag_name}-${targetAsset.name}`;\n\n  const fullFilePath = path.resolve(tmpdir, filename);\n  if (!await fs.pathExists(fullFilePath) || (await fs.stat(fullFilePath)).size !== targetAsset.size) {\n    await fs.mkdirs(tmpdir);\n\n    const nuggetOpts = {\n      target: filename,\n      dir: tmpdir,\n      resume: true,\n      strictSSL: true,\n    };\n    await pify(nugget)(targetAsset.browser_download_url, nuggetOpts);\n  }\n\n  await asyncOra('Installing Application', async (installSpinner) => {\n    const installActions = {\n      win32: {\n        '.exe': win32ExeInstaller,\n      },\n      darwin: {\n        '.zip': darwinZipInstaller,\n        '.dmg': darwinDMGInstaller,\n      },\n      linux: {\n        '.deb': linuxDebInstaller,\n        '.rpm': linuxRPMInstaller,\n      },\n    };\n\n    const suffixFnIdent = Object.keys(installActions[process.platform]).find(suffix => targetAsset.name.endsWith(suffix));\n    await installActions[process.platform][suffixFnIdent](fullFilePath, installSpinner);\n  });\n};\n"]}
;