From 4161babce106a32fb1ac50034c84d6804206ea86 Mon Sep 17 00:00:00 2001
From: "p.mikolajczak@tkhtechnology.com"
Date: Tue, 4 Apr 2023 15:14:23 +0200
Subject: [PATCH 1/3] fix: Mitigate production vulnrabilities
---
.gitignore | 1 -
dist/bin/cli.js | 224 ++
dist/binaryModulesDetector.js | 80 +
dist/defaultDependencies.js | 8 +
dist/dependenciesManager.js | 181 ++
dist/desktop.js | 271 ++
dist/electron.js | 61 +
dist/electronApp.js | 876 ++++++
dist/electronAppScaffold.js | 142 +
dist/electronBuilder.js | 384 +++
dist/env.js | 239 ++
dist/index.js | 247 ++
dist/log.js | 75 +
dist/meteorApp.js | 923 ++++++
dist/meteorManager.js | 147 +
dist/packager.js | 142 +
dist/scripts/addToScripts.js | 24 +
dist/scripts/propagateVersion.js | 21 +
dist/scripts/utils/addScript.js | 50 +
dist/skeletonDependencies.js | 24 +
dist/utils.js | 328 +++
lib/electronApp.js | 21 +-
lib/meteorApp.js | 10 +-
package-lock.json | 2718 +++++++++++-------
package.json | 49 +-
plugins/bundler/bundler.js | 21 +-
tests/functional/electronApp.test.js | 2 +-
tests/functional/modules/localServer.test.js | 8 +-
tests/unit/meteorApp.test.js | 2 +-
29 files changed, 6164 insertions(+), 1115 deletions(-)
create mode 100644 dist/bin/cli.js
create mode 100644 dist/binaryModulesDetector.js
create mode 100644 dist/defaultDependencies.js
create mode 100644 dist/dependenciesManager.js
create mode 100644 dist/desktop.js
create mode 100644 dist/electron.js
create mode 100644 dist/electronApp.js
create mode 100644 dist/electronAppScaffold.js
create mode 100644 dist/electronBuilder.js
create mode 100644 dist/env.js
create mode 100644 dist/index.js
create mode 100644 dist/log.js
create mode 100644 dist/meteorApp.js
create mode 100644 dist/meteorManager.js
create mode 100644 dist/packager.js
create mode 100644 dist/scripts/addToScripts.js
create mode 100644 dist/scripts/propagateVersion.js
create mode 100644 dist/scripts/utils/addScript.js
create mode 100644 dist/skeletonDependencies.js
create mode 100644 dist/utils.js
diff --git a/.gitignore b/.gitignore
index fd027d5c..28f46c1a 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,6 +1,5 @@
node_modules
.idea
-dist
tests/_tmp_
tests/.__tmp_int
.npm
diff --git a/dist/bin/cli.js b/dist/bin/cli.js
new file mode 100644
index 00000000..683607e0
--- /dev/null
+++ b/dist/bin/cli.js
@@ -0,0 +1,224 @@
+#!/usr/bin/env node
+
+/* eslint-disable global-require */
+"use strict";
+
+var _fs = _interopRequireDefault(require("fs"));
+
+var _path = _interopRequireDefault(require("path"));
+
+var _assignIn = _interopRequireDefault(require("lodash/assignIn"));
+
+var _commander = _interopRequireDefault(require("commander"));
+
+var _shelljs = _interopRequireDefault(require("shelljs"));
+
+var _ = _interopRequireDefault(require("../.."));
+
+var _addScript = _interopRequireDefault(require("../scripts/utils/addScript"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+const {
+ join
+} = _path.default;
+const cmd = process.argv[2];
+/* eslint-disable no-console */
+
+const {
+ log,
+ error,
+ info,
+ warn
+} = console;
+/* eslint-enable no-console */
+
+/**
+ * Looks for .meteor directory.
+ * @param {string} appPath - Meteor app path
+ */
+
+function isMeteorApp(appPath) {
+ const meteorPath = join(appPath, '.meteor');
+
+ try {
+ return _fs.default.statSync(meteorPath).isDirectory();
+ } catch (e) {
+ return false;
+ }
+}
+/**
+ * Just ensures a ddp url is set.
+ *
+ * @param {string|null} ddpUrl - the url that Meteor app connects to
+ * @returns {string|null}
+ */
+
+
+function getDdpUrl(ddpUrl = null) {
+ if (!ddpUrl && _commander.default.buildMeteor) {
+ info('no ddp_url specified, setting default: http://127.0.0.1:3000');
+ return 'http://127.0.0.1:3000';
+ }
+
+ return ddpUrl;
+} // --------------------------
+
+
+function collect(val, memo) {
+ memo.push(val);
+ return memo;
+}
+
+_commander.default.option('-b, --build-meteor', 'runs meteor to obtain the mobile build, kills it after').option('-t, --build-timeout ', 'timeout value when waiting for ' + 'meteor to build, default 600sec').option('-p, --port ', 'port on which meteor is running, when with -b this will be passed to meteor when obtaining the build').option('--production', 'builds meteor app with the production switch, uglifies contents ' + 'of .desktop, packs app to app.asar').option('-a, --android', 'force adding android as a mobile platform instead of ios').option('-s, --scaffold', 'will scaffold .desktop if not present').option('-i, --ignore-stderr [string]', 'only with -b, strings that when found will not terminate meteor build', collect, []).option('--meteor-settings ', 'only with -b, adds --settings options to meteor').option('--prod-debug', 'forces adding dev tools to a production build').option('--ia32', 'generate 32bit installer/package').option('--all-archs', 'generate 32bit and 64bit installers').option('--win', 'generate Windows installer').option('--linux', 'generate Linux installer').option('--mac', 'generate Mac installer').option('-d, --debug', 'run electron with debug switch');
+
+_commander.default.usage('[command] [options]').version(require('./../../package.json').version, '-V, --version').on('--help', () => {
+ log(' [ddp_url] - pass a ddp url if you want to use different one than used in meteor\'s --mobile-server');
+ log(' this will also work with -b');
+ log(' ');
+ log(' Examples:');
+ log('');
+ log(' ', ['# cd into meteor dir first', 'cd /your/meteor/app', 'meteor --mobile-server=127.0.0.1:3000', '', '# open new terminal, assuming you have done npm install --save-dev @meteor-community/meteor-desktop', 'npm run desktop -- init', 'npm run desktop'].join('\n '));
+ log('\n');
+});
+
+function verifyArgsSyntax() {
+ if (process.env.npm_config_argv) {
+ let npmArgv;
+
+ try {
+ const args = ['-b', '--build-meteor', '-t', '--build-timeout', '-p', '--port', '--production', '-a', '--android', '-s', '--scaffold', '--ia32', '--win', '--linux', '--all-archs', '--win', '--mac', '--meteor-settings'];
+ npmArgv = JSON.parse(process.env.npm_config_argv);
+
+ if (npmArgv.remain.length === 0 && npmArgv.original.length > 2) {
+ if (npmArgv.original.some(arg => !!~args.indexOf(arg))) {
+ warn('WARNING: seems that you might used the wrong console syntax, no ` --' + ' ` delimiter was found, be sure you are invoking meteor-desktop with' + ' it when passing commands or options -> ' + '`npm run desktop -- command --option`\n');
+ }
+ }
+ } catch (e) {// Not sure if `npm_config_argv` is always present...
+ }
+ }
+}
+
+function meteorDesktopFactory(ddpUrl, production = false) {
+ info(`METEOR-DESKTOP v${require('./../../package.json').version}\n`);
+ verifyArgsSyntax();
+ const input = process.cwd();
+
+ if (!isMeteorApp(input)) {
+ error(`not in a meteor app dir\n ${input}`);
+ process.exit();
+ }
+
+ if (!_commander.default.output) {
+ _commander.default.output = input;
+ }
+
+ if (production && !_commander.default.production) {
+ info('package/build-installer implies setting --production, setting it for you');
+ }
+
+ if (!_commander.default.buildMeteor) {
+ _commander.default.port = _commander.default.port || 3000;
+ info(`REMINDER: your Meteor project should be running now on port ${_commander.default.port}\n`);
+ }
+
+ if (_commander.default.prodDebug) {
+ info('!! WARNING: You are adding devTools to a production build !!\n');
+ }
+
+ const options = {
+ ddpUrl,
+ skipMobileBuild: _commander.default.buildMeteor ? !_commander.default.buildMeteor : true,
+ production: _commander.default.production || production
+ };
+ (0, _assignIn.default)(options, _commander.default);
+ return (0, _.default)(input, _commander.default.output, options);
+}
+
+function run(ddpUrl) {
+ meteorDesktopFactory(getDdpUrl(ddpUrl)).run();
+}
+
+function build(ddpUrl) {
+ meteorDesktopFactory(getDdpUrl(ddpUrl)).build();
+}
+
+function init() {
+ meteorDesktopFactory().init();
+}
+
+function justRun() {
+ meteorDesktopFactory().justRun();
+}
+
+function runPackager(ddpUrl) {
+ meteorDesktopFactory(getDdpUrl(ddpUrl), true).runPackager();
+}
+
+function buildInstaller(ddpUrl) {
+ meteorDesktopFactory(getDdpUrl(ddpUrl), true).buildInstaller();
+}
+
+function initTestsSupport() {
+ log('installing cross-env, ava, meteor-desktop-test-suite and spectron');
+ log('running `meteor npm install --save-dev cross-env ava spectron meteor-desktop-test-suite`');
+
+ const {
+ code
+ } = _shelljs.default.exec('meteor npm install --save-dev cross-env ava spectron meteor-desktop-test-suite');
+
+ if (code !== 0) {
+ warn('could not add cross-env, ava and spectron to your `devDependencies`, please do it' + ' manually');
+ }
+
+ const test = 'cross-env NODE_ENV=test ava .desktop/**/*.test.js -s --verbose';
+ const testWatch = 'cross-env NODE_ENV=test ava .desktop/**/*.test.js -s --verbose' + ' --watch --source .desktop';
+
+ function fail() {
+ error('\ncould not add entries to `scripts` in package.json');
+ log('please try to add it manually\n');
+ log(`test-desktop: ${test}`);
+ log(`test-desktop-watch: ${testWatch}`);
+ }
+
+ const packageJsonPath = _path.default.resolve(_path.default.join(process.cwd(), 'package.json'));
+
+ (0, _addScript.default)('test-desktop', test, packageJsonPath, fail);
+ (0, _addScript.default)('test-desktop-watch', testWatch, packageJsonPath, fail);
+ log('\nadded test-desktop and test-desktop-watch entries');
+ log('run the test with `npm run test-desktop`');
+}
+
+_commander.default.command('init').description('scaffolds .desktop dir in the meteor app').action(init);
+
+_commander.default.command('run [ddp_url]').description('(default) builds and runs desktop app').action(run);
+
+_commander.default.command('build [ddp_url]').description('builds your desktop app').action(build);
+
+_commander.default.command('build-installer [ddp_url]').description('creates the installer').action(buildInstaller);
+
+_commander.default.command('just-run').description('alias for running `electron .` in `.meteor/desktop-build`').action(justRun);
+
+_commander.default.command('package [ddp_url]').description('runs electron packager').action(runPackager);
+
+_commander.default.command('init-tests-support').description('prepares project for running functional tests of desktop app').action(initTestsSupport);
+
+if (process.argv.length === 2 || !~'-h|--help|run|init|build|build-installer|just-run|init-tests-support|package'.indexOf(cmd)) {
+ let {
+ argv
+ } = process;
+
+ if (process.argv.length === 2) {
+ argv.push('run');
+ } else {
+ let command = argv.splice(0, 2);
+ command = command.concat('run', argv);
+ argv = command;
+ }
+
+ _commander.default.parse(argv);
+} else {
+ _commander.default.parse(process.argv);
+}
+//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["join","path","cmd","process","argv","log","error","info","warn","console","isMeteorApp","appPath","meteorPath","fs","statSync","isDirectory","e","getDdpUrl","ddpUrl","program","buildMeteor","collect","val","memo","push","option","usage","version","require","on","verifyArgsSyntax","env","npm_config_argv","npmArgv","args","JSON","parse","remain","length","original","some","arg","indexOf","meteorDesktopFactory","production","input","cwd","exit","output","port","prodDebug","options","skipMobileBuild","assignIn","meteorDesktop","run","build","init","justRun","runPackager","buildInstaller","initTestsSupport","code","shell","exec","test","testWatch","fail","packageJsonPath","resolve","addScript","command","description","action","splice","concat"],"sources":["../../lib/bin/cli.js"],"sourcesContent":["#!/usr/bin/env node\n/* eslint-disable global-require */\nimport fs from 'fs';\nimport path from 'path';\nimport assignIn from 'lodash/assignIn';\nimport program from 'commander';\nimport shell from 'shelljs';\n\nimport meteorDesktop from '../..';\nimport addScript from '../scripts/utils/addScript';\n\nconst { join } = path;\nconst cmd = process.argv[2];\n\n/* eslint-disable no-console */\nconst {\n    log, error, info, warn\n} = console;\n\n/* eslint-enable no-console */\n\n/**\n * Looks for .meteor directory.\n * @param {string} appPath - Meteor app path\n */\nfunction isMeteorApp(appPath) {\n    const meteorPath = join(appPath, '.meteor');\n    try {\n        return fs.statSync(meteorPath).isDirectory();\n    } catch (e) {\n        return false;\n    }\n}\n\n/**\n * Just ensures a ddp url is set.\n *\n * @param {string|null} ddpUrl - the url that Meteor app connects to\n * @returns {string|null}\n */\nfunction getDdpUrl(ddpUrl = null) {\n    if (!ddpUrl && program.buildMeteor) {\n        info('no ddp_url specified, setting default: http://127.0.0.1:3000');\n        return 'http://127.0.0.1:3000';\n    }\n    return ddpUrl;\n}\n\n// --------------------------\n\nfunction collect(val, memo) {\n    memo.push(val);\n    return memo;\n}\n\nprogram\n    .option('-b, --build-meteor', 'runs meteor to obtain the mobile build, kills it after')\n    .option('-t, --build-timeout <timeout_in_sec>', 'timeout value when waiting for ' +\n        'meteor to build, default 600sec')\n    .option('-p, --port <port>', 'port on which meteor is running, when with -b this will be passed to meteor when obtaining the build')\n    .option('--production', 'builds meteor app with the production switch, uglifies contents ' +\n        'of .desktop, packs app to app.asar')\n    .option('-a, --android', 'force adding android as a mobile platform instead of ios')\n    .option('-s, --scaffold', 'will scaffold .desktop if not present')\n    .option('-i, --ignore-stderr [string]', 'only with -b, strings that when found will not terminate meteor build', collect, [])\n    .option('--meteor-settings <path>', 'only with -b, adds --settings options to meteor')\n    .option('--prod-debug', 'forces adding dev tools to a production build')\n    .option('--ia32', 'generate 32bit installer/package')\n    .option('--all-archs', 'generate 32bit and 64bit installers')\n    .option('--win', 'generate Windows installer')\n    .option('--linux', 'generate Linux installer')\n    .option('--mac', 'generate Mac installer')\n    .option('-d, --debug', 'run electron with debug switch');\n\n\nprogram\n    .usage('[command] [options]')\n    .version(require('./../../package.json').version, '-V, --version')\n    .on('--help', () => {\n        log('  [ddp_url] - pass a ddp url if you want to use different one than used in meteor\\'s --mobile-server');\n        log('              this will also work with -b');\n        log('    ');\n        log('  Examples:');\n        log('');\n        log(\n            '   ',\n            [\n                '# cd into meteor dir first',\n                'cd /your/meteor/app',\n                'meteor --mobile-server=127.0.0.1:3000',\n                '',\n                '# open new terminal, assuming you have done npm install --save-dev @meteor-community/meteor-desktop',\n                'npm run desktop -- init',\n                'npm run desktop'\n            ].join('\\n    ')\n        );\n        log('\\n');\n    });\n\n\nfunction verifyArgsSyntax() {\n    if (process.env.npm_config_argv) {\n        let npmArgv;\n        try {\n            const args = ['-b', '--build-meteor', '-t', '--build-timeout', '-p', '--port',\n                '--production', '-a', '--android', '-s', '--scaffold', '--ia32', '--win',\n                '--linux', '--all-archs', '--win', '--mac', '--meteor-settings'];\n            npmArgv = JSON.parse(process.env.npm_config_argv);\n            if (npmArgv.remain.length === 0 && npmArgv.original.length > 2) {\n                if (npmArgv.original.some(arg => !!~args.indexOf(arg))) {\n                    warn('WARNING: seems that you might used the wrong console syntax, no ` --' +\n                        ' ` delimiter was found, be sure you are invoking meteor-desktop with' +\n                        ' it when passing commands or options -> ' +\n                        '`npm run desktop -- command --option`\\n');\n                }\n            }\n        } catch (e) {\n            // Not sure if `npm_config_argv` is always present...\n        }\n    }\n}\n\nfunction meteorDesktopFactory(ddpUrl, production = false) {\n    info(`METEOR-DESKTOP v${require('./../../package.json').version}\\n`);\n\n    verifyArgsSyntax();\n\n    const input = process.cwd();\n\n    if (!isMeteorApp(input)) {\n        error(`not in a meteor app dir\\n ${input}`);\n        process.exit();\n    }\n\n    if (!program.output) {\n        program.output = input;\n    }\n\n    if (production && !program.production) {\n        info('package/build-installer implies setting --production, setting it for you');\n    }\n\n    if (!program.buildMeteor) {\n        program.port = program.port || 3000;\n        info(`REMINDER: your Meteor project should be running now on port ${program.port}\\n`);\n    }\n\n    if (program.prodDebug) {\n        info('!! WARNING: You are adding devTools to a production build !!\\n');\n    }\n\n    const options = {\n        ddpUrl,\n        skipMobileBuild: program.buildMeteor ? !program.buildMeteor : true,\n        production: program.production || production\n    };\n\n    assignIn(options, program);\n\n    return meteorDesktop(\n        input,\n        program.output,\n        options\n    );\n}\n\nfunction run(ddpUrl) {\n    meteorDesktopFactory(getDdpUrl(ddpUrl)).run();\n}\n\nfunction build(ddpUrl) {\n    meteorDesktopFactory(getDdpUrl(ddpUrl)).build();\n}\n\nfunction init() {\n    meteorDesktopFactory().init();\n}\n\nfunction justRun() {\n    meteorDesktopFactory().justRun();\n}\n\nfunction runPackager(ddpUrl) {\n    meteorDesktopFactory(getDdpUrl(ddpUrl), true).runPackager();\n}\n\nfunction buildInstaller(ddpUrl) {\n    meteorDesktopFactory(getDdpUrl(ddpUrl), true).buildInstaller();\n}\n\nfunction initTestsSupport() {\n    log('installing cross-env, ava, meteor-desktop-test-suite and spectron');\n    log('running `meteor npm install --save-dev cross-env ava spectron meteor-desktop-test-suite`');\n\n    const { code } = shell.exec('meteor npm install --save-dev cross-env ava spectron meteor-desktop-test-suite');\n\n    if (code !== 0) {\n        warn('could not add cross-env, ava and spectron to your `devDependencies`, please do it' +\n            ' manually');\n    }\n\n    const test = 'cross-env NODE_ENV=test ava .desktop/**/*.test.js -s --verbose';\n    const testWatch = 'cross-env NODE_ENV=test ava .desktop/**/*.test.js -s --verbose' +\n        ' --watch --source .desktop';\n\n    function fail() {\n        error('\\ncould not add entries to `scripts` in package.json');\n        log('please try to add it manually\\n');\n        log(`test-desktop: ${test}`);\n        log(`test-desktop-watch: ${testWatch}`);\n    }\n\n    const packageJsonPath = path.resolve(\n        path.join(process.cwd(), 'package.json')\n    );\n\n    addScript('test-desktop', test, packageJsonPath, fail);\n    addScript('test-desktop-watch', testWatch, packageJsonPath, fail);\n\n    log('\\nadded test-desktop and test-desktop-watch entries');\n    log('run the test with `npm run test-desktop`');\n}\n\nprogram\n    .command('init')\n    .description('scaffolds .desktop dir in the meteor app')\n    .action(init);\n\nprogram\n    .command('run [ddp_url]')\n    .description('(default) builds and runs desktop app')\n    .action(run);\n\nprogram\n    .command('build [ddp_url]')\n    .description('builds your desktop app')\n    .action(build);\n\nprogram\n    .command('build-installer [ddp_url]')\n    .description('creates the installer')\n    .action(buildInstaller);\n\nprogram\n    .command('just-run')\n    .description('alias for running `electron .` in `.meteor/desktop-build`')\n    .action(justRun);\n\nprogram\n    .command('package [ddp_url]')\n    .description('runs electron packager')\n    .action(runPackager);\n\nprogram\n    .command('init-tests-support')\n    .description('prepares project for running functional tests of desktop app')\n    .action(initTestsSupport);\n\nif (process.argv.length === 2 || !~('-h|--help|run|init|build|build-installer|just-run|init-tests-support|package'.indexOf(cmd))\n) {\n    let { argv } = process;\n    if (process.argv.length === 2) {\n        argv.push('run');\n    } else {\n        let command = argv.splice(0, 2);\n        command = command.concat('run', argv);\n        argv = command;\n    }\n    program.parse(argv);\n} else {\n    program.parse(process.argv);\n}\n"],"mappings":"AAAA;;AACA;;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA;;AACA;;;;AAEA,MAAM;EAAEA;AAAF,IAAWC,aAAjB;AACA,MAAMC,GAAG,GAAGC,OAAO,CAACC,IAAR,CAAa,CAAb,CAAZ;AAEA;;AACA,MAAM;EACFC,GADE;EACGC,KADH;EACUC,IADV;EACgBC;AADhB,IAEFC,OAFJ;AAIA;;AAEA;AACA;AACA;AACA;;AACA,SAASC,WAAT,CAAqBC,OAArB,EAA8B;EAC1B,MAAMC,UAAU,GAAGZ,IAAI,CAACW,OAAD,EAAU,SAAV,CAAvB;;EACA,IAAI;IACA,OAAOE,WAAA,CAAGC,QAAH,CAAYF,UAAZ,EAAwBG,WAAxB,EAAP;EACH,CAFD,CAEE,OAAOC,CAAP,EAAU;IACR,OAAO,KAAP;EACH;AACJ;AAED;AACA;AACA;AACA;AACA;AACA;;;AACA,SAASC,SAAT,CAAmBC,MAAM,GAAG,IAA5B,EAAkC;EAC9B,IAAI,CAACA,MAAD,IAAWC,kBAAA,CAAQC,WAAvB,EAAoC;IAChCb,IAAI,CAAC,8DAAD,CAAJ;IACA,OAAO,uBAAP;EACH;;EACD,OAAOW,MAAP;AACH,C,CAED;;;AAEA,SAASG,OAAT,CAAiBC,GAAjB,EAAsBC,IAAtB,EAA4B;EACxBA,IAAI,CAACC,IAAL,CAAUF,GAAV;EACA,OAAOC,IAAP;AACH;;AAEDJ,kBAAA,CACKM,MADL,CACY,oBADZ,EACkC,wDADlC,EAEKA,MAFL,CAEY,sCAFZ,EAEoD,oCAC5C,iCAHR,EAIKA,MAJL,CAIY,mBAJZ,EAIiC,sGAJjC,EAKKA,MALL,CAKY,cALZ,EAK4B,qEACpB,oCANR,EAOKA,MAPL,CAOY,eAPZ,EAO6B,0DAP7B,EAQKA,MARL,CAQY,gBARZ,EAQ8B,uCAR9B,EASKA,MATL,CASY,8BATZ,EAS4C,uEAT5C,EASqHJ,OATrH,EAS8H,EAT9H,EAUKI,MAVL,CAUY,0BAVZ,EAUwC,iDAVxC,EAWKA,MAXL,CAWY,cAXZ,EAW4B,+CAX5B,EAYKA,MAZL,CAYY,QAZZ,EAYsB,kCAZtB,EAaKA,MAbL,CAaY,aAbZ,EAa2B,qCAb3B,EAcKA,MAdL,CAcY,OAdZ,EAcqB,4BAdrB,EAeKA,MAfL,CAeY,SAfZ,EAeuB,0BAfvB,EAgBKA,MAhBL,CAgBY,OAhBZ,EAgBqB,wBAhBrB,EAiBKA,MAjBL,CAiBY,aAjBZ,EAiB2B,gCAjB3B;;AAoBAN,kBAAA,CACKO,KADL,CACW,qBADX,EAEKC,OAFL,CAEaC,OAAO,CAAC,sBAAD,CAAP,CAAgCD,OAF7C,EAEsD,eAFtD,EAGKE,EAHL,CAGQ,QAHR,EAGkB,MAAM;EAChBxB,GAAG,CAAC,sGAAD,CAAH;EACAA,GAAG,CAAC,2CAAD,CAAH;EACAA,GAAG,CAAC,MAAD,CAAH;EACAA,GAAG,CAAC,aAAD,CAAH;EACAA,GAAG,CAAC,EAAD,CAAH;EACAA,GAAG,CACC,KADD,EAEC,CACI,4BADJ,EAEI,qBAFJ,EAGI,uCAHJ,EAII,EAJJ,EAKI,qGALJ,EAMI,yBANJ,EAOI,iBAPJ,EAQEL,IARF,CAQO,QARP,CAFD,CAAH;EAYAK,GAAG,CAAC,IAAD,CAAH;AACH,CAtBL;;AAyBA,SAASyB,gBAAT,GAA4B;EACxB,IAAI3B,OAAO,CAAC4B,GAAR,CAAYC,eAAhB,EAAiC;IAC7B,IAAIC,OAAJ;;IACA,IAAI;MACA,MAAMC,IAAI,GAAG,CAAC,IAAD,EAAO,gBAAP,EAAyB,IAAzB,EAA+B,iBAA/B,EAAkD,IAAlD,EAAwD,QAAxD,EACT,cADS,EACO,IADP,EACa,WADb,EAC0B,IAD1B,EACgC,YADhC,EAC8C,QAD9C,EACwD,OADxD,EAET,SAFS,EAEE,aAFF,EAEiB,OAFjB,EAE0B,OAF1B,EAEmC,mBAFnC,CAAb;MAGAD,OAAO,GAAGE,IAAI,CAACC,KAAL,CAAWjC,OAAO,CAAC4B,GAAR,CAAYC,eAAvB,CAAV;;MACA,IAAIC,OAAO,CAACI,MAAR,CAAeC,MAAf,KAA0B,CAA1B,IAA+BL,OAAO,CAACM,QAAR,CAAiBD,MAAjB,GAA0B,CAA7D,EAAgE;QAC5D,IAAIL,OAAO,CAACM,QAAR,CAAiBC,IAAjB,CAAsBC,GAAG,IAAI,CAAC,CAAC,CAACP,IAAI,CAACQ,OAAL,CAAaD,GAAb,CAAhC,CAAJ,EAAwD;UACpDjC,IAAI,CAAC,yEACD,sEADC,GAED,0CAFC,GAGD,yCAHA,CAAJ;QAIH;MACJ;IACJ,CAbD,CAaE,OAAOQ,CAAP,EAAU,CACR;IACH;EACJ;AACJ;;AAED,SAAS2B,oBAAT,CAA8BzB,MAA9B,EAAsC0B,UAAU,GAAG,KAAnD,EAA0D;EACtDrC,IAAI,CAAE,mBAAkBqB,OAAO,CAAC,sBAAD,CAAP,CAAgCD,OAAQ,IAA5D,CAAJ;EAEAG,gBAAgB;EAEhB,MAAMe,KAAK,GAAG1C,OAAO,CAAC2C,GAAR,EAAd;;EAEA,IAAI,CAACpC,WAAW,CAACmC,KAAD,CAAhB,EAAyB;IACrBvC,KAAK,CAAE,6BAA4BuC,KAAM,EAApC,CAAL;IACA1C,OAAO,CAAC4C,IAAR;EACH;;EAED,IAAI,CAAC5B,kBAAA,CAAQ6B,MAAb,EAAqB;IACjB7B,kBAAA,CAAQ6B,MAAR,GAAiBH,KAAjB;EACH;;EAED,IAAID,UAAU,IAAI,CAACzB,kBAAA,CAAQyB,UAA3B,EAAuC;IACnCrC,IAAI,CAAC,0EAAD,CAAJ;EACH;;EAED,IAAI,CAACY,kBAAA,CAAQC,WAAb,EAA0B;IACtBD,kBAAA,CAAQ8B,IAAR,GAAe9B,kBAAA,CAAQ8B,IAAR,IAAgB,IAA/B;IACA1C,IAAI,CAAE,+DAA8DY,kBAAA,CAAQ8B,IAAK,IAA7E,CAAJ;EACH;;EAED,IAAI9B,kBAAA,CAAQ+B,SAAZ,EAAuB;IACnB3C,IAAI,CAAC,gEAAD,CAAJ;EACH;;EAED,MAAM4C,OAAO,GAAG;IACZjC,MADY;IAEZkC,eAAe,EAAEjC,kBAAA,CAAQC,WAAR,GAAsB,CAACD,kBAAA,CAAQC,WAA/B,GAA6C,IAFlD;IAGZwB,UAAU,EAAEzB,kBAAA,CAAQyB,UAAR,IAAsBA;EAHtB,CAAhB;EAMA,IAAAS,iBAAA,EAASF,OAAT,EAAkBhC,kBAAlB;EAEA,OAAO,IAAAmC,SAAA,EACHT,KADG,EAEH1B,kBAAA,CAAQ6B,MAFL,EAGHG,OAHG,CAAP;AAKH;;AAED,SAASI,GAAT,CAAarC,MAAb,EAAqB;EACjByB,oBAAoB,CAAC1B,SAAS,CAACC,MAAD,CAAV,CAApB,CAAwCqC,GAAxC;AACH;;AAED,SAASC,KAAT,CAAetC,MAAf,EAAuB;EACnByB,oBAAoB,CAAC1B,SAAS,CAACC,MAAD,CAAV,CAApB,CAAwCsC,KAAxC;AACH;;AAED,SAASC,IAAT,GAAgB;EACZd,oBAAoB,GAAGc,IAAvB;AACH;;AAED,SAASC,OAAT,GAAmB;EACff,oBAAoB,GAAGe,OAAvB;AACH;;AAED,SAASC,WAAT,CAAqBzC,MAArB,EAA6B;EACzByB,oBAAoB,CAAC1B,SAAS,CAACC,MAAD,CAAV,EAAoB,IAApB,CAApB,CAA8CyC,WAA9C;AACH;;AAED,SAASC,cAAT,CAAwB1C,MAAxB,EAAgC;EAC5ByB,oBAAoB,CAAC1B,SAAS,CAACC,MAAD,CAAV,EAAoB,IAApB,CAApB,CAA8C0C,cAA9C;AACH;;AAED,SAASC,gBAAT,GAA4B;EACxBxD,GAAG,CAAC,mEAAD,CAAH;EACAA,GAAG,CAAC,0FAAD,CAAH;;EAEA,MAAM;IAAEyD;EAAF,IAAWC,gBAAA,CAAMC,IAAN,CAAW,gFAAX,CAAjB;;EAEA,IAAIF,IAAI,KAAK,CAAb,EAAgB;IACZtD,IAAI,CAAC,sFACD,WADA,CAAJ;EAEH;;EAED,MAAMyD,IAAI,GAAG,gEAAb;EACA,MAAMC,SAAS,GAAG,mEACd,4BADJ;;EAGA,SAASC,IAAT,GAAgB;IACZ7D,KAAK,CAAC,sDAAD,CAAL;IACAD,GAAG,CAAC,iCAAD,CAAH;IACAA,GAAG,CAAE,iBAAgB4D,IAAK,EAAvB,CAAH;IACA5D,GAAG,CAAE,uBAAsB6D,SAAU,EAAlC,CAAH;EACH;;EAED,MAAME,eAAe,GAAGnE,aAAA,CAAKoE,OAAL,CACpBpE,aAAA,CAAKD,IAAL,CAAUG,OAAO,CAAC2C,GAAR,EAAV,EAAyB,cAAzB,CADoB,CAAxB;;EAIA,IAAAwB,kBAAA,EAAU,cAAV,EAA0BL,IAA1B,EAAgCG,eAAhC,EAAiDD,IAAjD;EACA,IAAAG,kBAAA,EAAU,oBAAV,EAAgCJ,SAAhC,EAA2CE,eAA3C,EAA4DD,IAA5D;EAEA9D,GAAG,CAAC,qDAAD,CAAH;EACAA,GAAG,CAAC,0CAAD,CAAH;AACH;;AAEDc,kBAAA,CACKoD,OADL,CACa,MADb,EAEKC,WAFL,CAEiB,0CAFjB,EAGKC,MAHL,CAGYhB,IAHZ;;AAKAtC,kBAAA,CACKoD,OADL,CACa,eADb,EAEKC,WAFL,CAEiB,uCAFjB,EAGKC,MAHL,CAGYlB,GAHZ;;AAKApC,kBAAA,CACKoD,OADL,CACa,iBADb,EAEKC,WAFL,CAEiB,yBAFjB,EAGKC,MAHL,CAGYjB,KAHZ;;AAKArC,kBAAA,CACKoD,OADL,CACa,2BADb,EAEKC,WAFL,CAEiB,uBAFjB,EAGKC,MAHL,CAGYb,cAHZ;;AAKAzC,kBAAA,CACKoD,OADL,CACa,UADb,EAEKC,WAFL,CAEiB,2DAFjB,EAGKC,MAHL,CAGYf,OAHZ;;AAKAvC,kBAAA,CACKoD,OADL,CACa,mBADb,EAEKC,WAFL,CAEiB,wBAFjB,EAGKC,MAHL,CAGYd,WAHZ;;AAKAxC,kBAAA,CACKoD,OADL,CACa,oBADb,EAEKC,WAFL,CAEiB,8DAFjB,EAGKC,MAHL,CAGYZ,gBAHZ;;AAKA,IAAI1D,OAAO,CAACC,IAAR,CAAakC,MAAb,KAAwB,CAAxB,IAA6B,CAAC,CAAE,+EAA+EI,OAA/E,CAAuFxC,GAAvF,CAApC,EACE;EACE,IAAI;IAAEE;EAAF,IAAWD,OAAf;;EACA,IAAIA,OAAO,CAACC,IAAR,CAAakC,MAAb,KAAwB,CAA5B,EAA+B;IAC3BlC,IAAI,CAACoB,IAAL,CAAU,KAAV;EACH,CAFD,MAEO;IACH,IAAI+C,OAAO,GAAGnE,IAAI,CAACsE,MAAL,CAAY,CAAZ,EAAe,CAAf,CAAd;IACAH,OAAO,GAAGA,OAAO,CAACI,MAAR,CAAe,KAAf,EAAsBvE,IAAtB,CAAV;IACAA,IAAI,GAAGmE,OAAP;EACH;;EACDpD,kBAAA,CAAQiB,KAAR,CAAchC,IAAd;AACH,CAXD,MAWO;EACHe,kBAAA,CAAQiB,KAAR,CAAcjC,OAAO,CAACC,IAAtB;AACH"}
\ No newline at end of file
diff --git a/dist/binaryModulesDetector.js b/dist/binaryModulesDetector.js
new file mode 100644
index 00000000..a074f7bb
--- /dev/null
+++ b/dist/binaryModulesDetector.js
@@ -0,0 +1,80 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = void 0;
+
+var _path = _interopRequireDefault(require("path"));
+
+var _isbinaryfile = _interopRequireDefault(require("isbinaryfile"));
+
+var _shelljs = _interopRequireDefault(require("shelljs"));
+
+var _log = _interopRequireDefault(require("./log"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+_shelljs.default.config.fatal = true;
+/**
+ * Experimental module for detecting modules containing binary files.
+ * Based on the same functionality from electron-builder.
+ *
+ * @property {MeteorDesktop} $
+ * @class
+ */
+
+class BinaryModulesDetector {
+ /**
+ * @constructor
+ */
+ constructor(nodeModulesPath) {
+ this.log = new _log.default('binaryModulesDetector');
+ this.nodeModulesPath = nodeModulesPath;
+ } // TODO: make asynchronous
+
+
+ detect() {
+ this.log.verbose('detecting node modules with binary files');
+
+ const files = _shelljs.default.ls('-RAl', this.nodeModulesPath);
+
+ const extract = [];
+ files.forEach(file => {
+ const pathSplit = file.name.split(_path.default.posix.sep);
+ const dir = pathSplit[0];
+ const filename = pathSplit.pop();
+
+ if (extract.indexOf(dir) === -1 && !BinaryModulesDetector.shouldBeIgnored(dir, filename)) {
+ if (file.isFile()) {
+ let shouldUnpack = false;
+
+ if (file.name.endsWith('.dll') || file.name.endsWith('.exe') || file.name.endsWith('.dylib')) {
+ shouldUnpack = true;
+ } else if (_path.default.extname(file.name) === '') {
+ shouldUnpack = _isbinaryfile.default.sync(_path.default.join(this.nodeModulesPath, file.name));
+ }
+
+ if (shouldUnpack) {
+ this.log.debug(`binary file: ${file.name}`);
+ extract.push(dir);
+ }
+ }
+ }
+ });
+
+ if (extract.length > 0) {
+ this.log.verbose(`detected modules to be extracted: ${extract.join(', ')}`);
+ }
+
+ return extract;
+ }
+
+ static shouldBeIgnored(dir, filename) {
+ return dir === '.bin' || filename === '.DS_Store' || filename === 'LICENSE' || filename === 'README';
+ }
+
+}
+
+exports.default = BinaryModulesDetector;
+//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJzaGVsbCIsImNvbmZpZyIsImZhdGFsIiwiQmluYXJ5TW9kdWxlc0RldGVjdG9yIiwiY29uc3RydWN0b3IiLCJub2RlTW9kdWxlc1BhdGgiLCJsb2ciLCJMb2ciLCJkZXRlY3QiLCJ2ZXJib3NlIiwiZmlsZXMiLCJscyIsImV4dHJhY3QiLCJmb3JFYWNoIiwiZmlsZSIsInBhdGhTcGxpdCIsIm5hbWUiLCJzcGxpdCIsInBhdGgiLCJwb3NpeCIsInNlcCIsImRpciIsImZpbGVuYW1lIiwicG9wIiwiaW5kZXhPZiIsInNob3VsZEJlSWdub3JlZCIsImlzRmlsZSIsInNob3VsZFVucGFjayIsImVuZHNXaXRoIiwiZXh0bmFtZSIsImlzQmluYXJ5RmlsZSIsInN5bmMiLCJqb2luIiwiZGVidWciLCJwdXNoIiwibGVuZ3RoIl0sInNvdXJjZXMiOlsiLi4vbGliL2JpbmFyeU1vZHVsZXNEZXRlY3Rvci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCBpc0JpbmFyeUZpbGUgZnJvbSAnaXNiaW5hcnlmaWxlJztcbmltcG9ydCBzaGVsbCBmcm9tICdzaGVsbGpzJztcblxuaW1wb3J0IExvZyBmcm9tICcuL2xvZyc7XG5cbnNoZWxsLmNvbmZpZy5mYXRhbCA9IHRydWU7XG4vKipcbiAqIEV4cGVyaW1lbnRhbCBtb2R1bGUgZm9yIGRldGVjdGluZyBtb2R1bGVzIGNvbnRhaW5pbmcgYmluYXJ5IGZpbGVzLlxuICogQmFzZWQgb24gdGhlIHNhbWUgZnVuY3Rpb25hbGl0eSBmcm9tIGVsZWN0cm9uLWJ1aWxkZXIuXG4gKlxuICogQHByb3BlcnR5IHtNZXRlb3JEZXNrdG9wfSAkXG4gKiBAY2xhc3NcbiAqL1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgQmluYXJ5TW9kdWxlc0RldGVjdG9yIHtcbiAgICAvKipcbiAgICAgKiBAY29uc3RydWN0b3JcbiAgICAgKi9cbiAgICBjb25zdHJ1Y3Rvcihub2RlTW9kdWxlc1BhdGgpIHtcbiAgICAgICAgdGhpcy5sb2cgPSBuZXcgTG9nKCdiaW5hcnlNb2R1bGVzRGV0ZWN0b3InKTtcbiAgICAgICAgdGhpcy5ub2RlTW9kdWxlc1BhdGggPSBub2RlTW9kdWxlc1BhdGg7XG4gICAgfVxuXG4gICAgLy8gVE9ETzogbWFrZSBhc3luY2hyb25vdXNcbiAgICBkZXRlY3QoKSB7XG4gICAgICAgIHRoaXMubG9nLnZlcmJvc2UoJ2RldGVjdGluZyBub2RlIG1vZHVsZXMgd2l0aCBiaW5hcnkgZmlsZXMnKTtcbiAgICAgICAgY29uc3QgZmlsZXMgPSBzaGVsbC5scygnLVJBbCcsIHRoaXMubm9kZU1vZHVsZXNQYXRoKTtcblxuICAgICAgICBjb25zdCBleHRyYWN0ID0gW107XG5cbiAgICAgICAgZmlsZXMuZm9yRWFjaCgoZmlsZSkgPT4ge1xuICAgICAgICAgICAgY29uc3QgcGF0aFNwbGl0ID0gZmlsZS5uYW1lLnNwbGl0KHBhdGgucG9zaXguc2VwKTtcbiAgICAgICAgICAgIGNvbnN0IGRpciA9IHBhdGhTcGxpdFswXTtcbiAgICAgICAgICAgIGNvbnN0IGZpbGVuYW1lID0gcGF0aFNwbGl0LnBvcCgpO1xuXG4gICAgICAgICAgICBpZiAoZXh0cmFjdC5pbmRleE9mKGRpcikgPT09IC0xICYmXG4gICAgICAgICAgICAgICAgIUJpbmFyeU1vZHVsZXNEZXRlY3Rvci5zaG91bGRCZUlnbm9yZWQoZGlyLCBmaWxlbmFtZSlcbiAgICAgICAgICAgICkge1xuICAgICAgICAgICAgICAgIGlmIChmaWxlLmlzRmlsZSgpKSB7XG4gICAgICAgICAgICAgICAgICAgIGxldCBzaG91bGRVbnBhY2sgPSBmYWxzZTtcbiAgICAgICAgICAgICAgICAgICAgaWYgKGZpbGUubmFtZS5lbmRzV2l0aCgnLmRsbCcpIHx8IGZpbGUubmFtZS5lbmRzV2l0aCgnLmV4ZScpIHx8IGZpbGUubmFtZS5lbmRzV2l0aCgnLmR5bGliJykpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHNob3VsZFVucGFjayA9IHRydWU7XG4gICAgICAgICAgICAgICAgICAgIH0gZWxzZSBpZiAocGF0aC5leHRuYW1lKGZpbGUubmFtZSkgPT09ICcnKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBzaG91bGRVbnBhY2sgPVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlzQmluYXJ5RmlsZS5zeW5jKHBhdGguam9pbih0aGlzLm5vZGVNb2R1bGVzUGF0aCwgZmlsZS5uYW1lKSk7XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgaWYgKHNob3VsZFVucGFjaykge1xuICAgICAgICAgICAgICAgICAgICAgICAgdGhpcy5sb2cuZGVidWcoYGJpbmFyeSBmaWxlOiAke2ZpbGUubmFtZX1gKTtcbiAgICAgICAgICAgICAgICAgICAgICAgIGV4dHJhY3QucHVzaChkaXIpO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICB9KTtcbiAgICAgICAgaWYgKGV4dHJhY3QubGVuZ3RoID4gMCkge1xuICAgICAgICAgICAgdGhpcy5sb2cudmVyYm9zZShgZGV0ZWN0ZWQgbW9kdWxlcyB0byBiZSBleHRyYWN0ZWQ6ICR7ZXh0cmFjdC5qb2luKCcsICcpfWApO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiBleHRyYWN0O1xuICAgIH1cblxuICAgIHN0YXRpYyBzaG91bGRCZUlnbm9yZWQoZGlyLCBmaWxlbmFtZSkge1xuICAgICAgICByZXR1cm4gZGlyID09PSAnLmJpbicgfHwgZmlsZW5hbWUgPT09ICcuRFNfU3RvcmUnIHx8IGZpbGVuYW1lID09PSAnTElDRU5TRScgfHwgZmlsZW5hbWUgPT09ICdSRUFETUUnO1xuICAgIH1cbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUVBOzs7O0FBRUFBLGdCQUFBLENBQU1DLE1BQU4sQ0FBYUMsS0FBYixHQUFxQixJQUFyQjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUNlLE1BQU1DLHFCQUFOLENBQTRCO0VBQ3ZDO0FBQ0o7QUFDQTtFQUNJQyxXQUFXLENBQUNDLGVBQUQsRUFBa0I7SUFDekIsS0FBS0MsR0FBTCxHQUFXLElBQUlDLFlBQUosQ0FBUSx1QkFBUixDQUFYO0lBQ0EsS0FBS0YsZUFBTCxHQUF1QkEsZUFBdkI7RUFDSCxDQVBzQyxDQVN2Qzs7O0VBQ0FHLE1BQU0sR0FBRztJQUNMLEtBQUtGLEdBQUwsQ0FBU0csT0FBVCxDQUFpQiwwQ0FBakI7O0lBQ0EsTUFBTUMsS0FBSyxHQUFHVixnQkFBQSxDQUFNVyxFQUFOLENBQVMsTUFBVCxFQUFpQixLQUFLTixlQUF0QixDQUFkOztJQUVBLE1BQU1PLE9BQU8sR0FBRyxFQUFoQjtJQUVBRixLQUFLLENBQUNHLE9BQU4sQ0FBZUMsSUFBRCxJQUFVO01BQ3BCLE1BQU1DLFNBQVMsR0FBR0QsSUFBSSxDQUFDRSxJQUFMLENBQVVDLEtBQVYsQ0FBZ0JDLGFBQUEsQ0FBS0MsS0FBTCxDQUFXQyxHQUEzQixDQUFsQjtNQUNBLE1BQU1DLEdBQUcsR0FBR04sU0FBUyxDQUFDLENBQUQsQ0FBckI7TUFDQSxNQUFNTyxRQUFRLEdBQUdQLFNBQVMsQ0FBQ1EsR0FBVixFQUFqQjs7TUFFQSxJQUFJWCxPQUFPLENBQUNZLE9BQVIsQ0FBZ0JILEdBQWhCLE1BQXlCLENBQUMsQ0FBMUIsSUFDQSxDQUFDbEIscUJBQXFCLENBQUNzQixlQUF0QixDQUFzQ0osR0FBdEMsRUFBMkNDLFFBQTNDLENBREwsRUFFRTtRQUNFLElBQUlSLElBQUksQ0FBQ1ksTUFBTCxFQUFKLEVBQW1CO1VBQ2YsSUFBSUMsWUFBWSxHQUFHLEtBQW5COztVQUNBLElBQUliLElBQUksQ0FBQ0UsSUFBTCxDQUFVWSxRQUFWLENBQW1CLE1BQW5CLEtBQThCZCxJQUFJLENBQUNFLElBQUwsQ0FBVVksUUFBVixDQUFtQixNQUFuQixDQUE5QixJQUE0RGQsSUFBSSxDQUFDRSxJQUFMLENBQVVZLFFBQVYsQ0FBbUIsUUFBbkIsQ0FBaEUsRUFBOEY7WUFDMUZELFlBQVksR0FBRyxJQUFmO1VBQ0gsQ0FGRCxNQUVPLElBQUlULGFBQUEsQ0FBS1csT0FBTCxDQUFhZixJQUFJLENBQUNFLElBQWxCLE1BQTRCLEVBQWhDLEVBQW9DO1lBQ3ZDVyxZQUFZLEdBQ1JHLHFCQUFBLENBQWFDLElBQWIsQ0FBa0JiLGFBQUEsQ0FBS2MsSUFBTCxDQUFVLEtBQUszQixlQUFmLEVBQWdDUyxJQUFJLENBQUNFLElBQXJDLENBQWxCLENBREo7VUFFSDs7VUFDRCxJQUFJVyxZQUFKLEVBQWtCO1lBQ2QsS0FBS3JCLEdBQUwsQ0FBUzJCLEtBQVQsQ0FBZ0IsZ0JBQWVuQixJQUFJLENBQUNFLElBQUssRUFBekM7WUFDQUosT0FBTyxDQUFDc0IsSUFBUixDQUFhYixHQUFiO1VBQ0g7UUFDSjtNQUNKO0lBQ0osQ0F0QkQ7O0lBdUJBLElBQUlULE9BQU8sQ0FBQ3VCLE1BQVIsR0FBaUIsQ0FBckIsRUFBd0I7TUFDcEIsS0FBSzdCLEdBQUwsQ0FBU0csT0FBVCxDQUFrQixxQ0FBb0NHLE9BQU8sQ0FBQ29CLElBQVIsQ0FBYSxJQUFiLENBQW1CLEVBQXpFO0lBQ0g7O0lBQ0QsT0FBT3BCLE9BQVA7RUFDSDs7RUFFcUIsT0FBZmEsZUFBZSxDQUFDSixHQUFELEVBQU1DLFFBQU4sRUFBZ0I7SUFDbEMsT0FBT0QsR0FBRyxLQUFLLE1BQVIsSUFBa0JDLFFBQVEsS0FBSyxXQUEvQixJQUE4Q0EsUUFBUSxLQUFLLFNBQTNELElBQXdFQSxRQUFRLEtBQUssUUFBNUY7RUFDSDs7QUEvQ3NDIn0=
\ No newline at end of file
diff --git a/dist/defaultDependencies.js b/dist/defaultDependencies.js
new file mode 100644
index 00000000..c5232dcc
--- /dev/null
+++ b/dist/defaultDependencies.js
@@ -0,0 +1,8 @@
+"use strict";
+
+module.exports = {
+ electron: '11.5.0',
+ 'electron-builder': '23.3.1',
+ 'electron-packager': '15.4.0'
+};
+//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJtb2R1bGUiLCJleHBvcnRzIiwiZWxlY3Ryb24iXSwic291cmNlcyI6WyIuLi9saWIvZGVmYXVsdERlcGVuZGVuY2llcy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJtb2R1bGUuZXhwb3J0cyA9IHtcbiAgICBlbGVjdHJvbjogJzExLjUuMCcsXG4gICAgJ2VsZWN0cm9uLWJ1aWxkZXInOiAnMjMuMy4xJyxcbiAgICAnZWxlY3Ryb24tcGFja2FnZXInOiAnMTUuNC4wJ1xufTtcbiJdLCJtYXBwaW5ncyI6Ijs7QUFBQUEsTUFBTSxDQUFDQyxPQUFQLEdBQWlCO0VBQ2JDLFFBQVEsRUFBRSxRQURHO0VBRWIsb0JBQW9CLFFBRlA7RUFHYixxQkFBcUI7QUFIUixDQUFqQiJ9
\ No newline at end of file
diff --git a/dist/dependenciesManager.js b/dist/dependenciesManager.js
new file mode 100644
index 00000000..d5d4ac90
--- /dev/null
+++ b/dist/dependenciesManager.js
@@ -0,0 +1,181 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = void 0;
+
+var _runtime = _interopRequireDefault(require("regenerator-runtime/runtime"));
+
+var _lodash = require("lodash");
+
+var _log = _interopRequireDefault(require("./log"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+// eslint-disable-next-line no-unused-vars
+
+/**
+ * Utility class designed for merging dependencies list with simple validation and duplicate
+ * detection.
+ *
+ * @class
+ */
+class DependenciesManager {
+ /**
+ * @param {MeteorDesktop} $ - context
+ * @param {Object} defaultDependencies - core dependencies list
+ * @constructor
+ */
+ constructor($, defaultDependencies) {
+ this.log = new _log.default('dependenciesManager');
+ this.$ = $;
+ this.dependencies = defaultDependencies; // Regexes for matching certain types of dependencies version.
+ // https://docs.npmjs.com/files/package.json#dependencies
+
+ this.regexes = {
+ local: /^(\.\.\/|~\/|\.\/|\/)/,
+ git: /^git(\+(ssh|http)s?)?/,
+ github: /^\w+-?\w+(?!-)\//,
+ http: /^https?.+tar\.gz/,
+ file: /^file:/
+ }; // Check for commit hashes.
+
+ const gitCheck = {
+ type: 'regex',
+ regex: /#[a-f0-9]{7,40}/,
+ test: 'match',
+ message: 'git or github link must have a commit hash'
+ }; // Check for displaying warnings when npm package from local path is used.
+
+ const localCheck = {
+ onceName: 'localCheck',
+ type: 'warning',
+ message: 'using dependencies from local paths is permitted' + ' but dangerous - read more in README.md'
+ };
+ this.checks = {
+ local: localCheck,
+ file: localCheck,
+ git: gitCheck,
+ github: gitCheck,
+ version: {
+ type: 'regex',
+ // Matches all the semver ranges operators, empty strings and `*`.
+ regex: /[\^|><= ~-]|\.x|^$|^\*$/,
+ test: 'do not match',
+ message: 'semver ranges are forbidden, please specify exact version'
+ }
+ };
+ }
+ /**
+ * Just a public getter.
+ * @returns {Object}
+ */
+
+
+ getDependencies() {
+ return this.dependencies;
+ }
+ /**
+ * Returns local dependencies.
+ * @returns {Object}
+ */
+
+
+ getLocalDependencies() {
+ return Object.keys(this.dependencies).filter(dependency => this.regexes.local.test(this.dependencies[dependency]) || this.regexes.file.test(this.dependencies[dependency])).reduce((localDependencies, currentDependency) => Object.assign(localDependencies, {
+ [currentDependency]: this.dependencies[currentDependency]
+ }), {});
+ }
+ /**
+ * Returns remote dependencies.
+ * @returns {Object}
+ */
+
+
+ getRemoteDependencies() {
+ return Object.keys(this.dependencies).filter(dependency => !this.regexes.local.test(this.dependencies[dependency]) && !this.regexes.file.test(this.dependencies[dependency])).reduce((localDependencies, currentDependency) => Object.assign(localDependencies, {
+ [currentDependency]: this.dependencies[currentDependency]
+ }), {});
+ }
+ /**
+ * Merges dependencies into one list.
+ *
+ * @param {string} from - describes where the dependencies were set
+ * @param {Object} dependencies - dependencies list
+ */
+
+
+ mergeDependencies(from, dependencies) {
+ if (this.validateDependenciesVersions(from, dependencies)) {
+ this.detectDuplicatedDependencies(from, dependencies);
+ (0, _lodash.assignIn)(this.dependencies, dependencies);
+ }
+ }
+ /**
+ * Detects dependency version type.
+ * @param {string} version - version string of the dependency
+ * @return {string}
+ */
+
+
+ detectDependencyVersionType(version) {
+ const type = Object.keys(this.regexes).find(dependencyType => this.regexes[dependencyType].test(version));
+ return type || 'version';
+ }
+ /**
+ * Validates semver and detect ranges.
+ *
+ * @param {string} from - describes where the dependencies were set
+ * @param {Object} dependencies - dependencies list
+ */
+
+
+ validateDependenciesVersions(from, dependencies) {
+ const warningsShown = {};
+ (0, _lodash.forEach)(dependencies, (version, name) => {
+ const type = this.detectDependencyVersionType(version);
+
+ if (this.checks[type]) {
+ const check = this.checks[type];
+
+ if (check.type === 'regex') {
+ const checkResult = check.test === 'match' ? this.checks[type].regex.test(version) : !this.checks[type].regex.test(version);
+
+ if (!checkResult) {
+ throw new Error(`dependency ${name}:${version} from ${from} failed version ` + `check with message: ${this.checks[type].message}`);
+ }
+ }
+
+ if (check.type === 'warning' && !warningsShown[check.onceName]) {
+ warningsShown[check.onceName] = true;
+ this.log.warn(`dependency ${name}:${version} from ${from} caused a` + ` warning: ${check.message}`);
+ }
+ }
+ });
+ return true;
+ }
+ /**
+ * Detects duplicates.
+ *
+ * @param {string} from - describes where the dependencies were set
+ * @param {Object} dependencies - dependencies list
+ */
+
+
+ detectDuplicatedDependencies(from, dependencies) {
+ const duplicates = (0, _lodash.intersection)(Object.keys(dependencies), Object.keys(this.dependencies));
+
+ if (duplicates.length > 0) {
+ duplicates.forEach(name => {
+ if (dependencies[name] !== this.dependencies[name]) {
+ throw new Error(`While processing dependencies from ${from}, a dependency ` + `${name}: ${dependencies[name]} was found to be conflicting with a ` + `dependency (${this.dependencies[name]}) that was already declared in ` + 'other module or it is used in core of the electron app.');
+ }
+ });
+ }
+ }
+
+}
+
+exports.default = DependenciesManager;
+//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["DependenciesManager","constructor","$","defaultDependencies","log","Log","dependencies","regexes","local","git","github","http","file","gitCheck","type","regex","test","message","localCheck","onceName","checks","version","getDependencies","getLocalDependencies","Object","keys","filter","dependency","reduce","localDependencies","currentDependency","assign","getRemoteDependencies","mergeDependencies","from","validateDependenciesVersions","detectDuplicatedDependencies","assignIn","detectDependencyVersionType","find","dependencyType","warningsShown","forEach","name","check","checkResult","Error","warn","duplicates","intersection","length"],"sources":["../lib/dependenciesManager.js"],"sourcesContent":["// eslint-disable-next-line no-unused-vars\nimport regeneratorRuntime from 'regenerator-runtime/runtime';\nimport { forEach, assignIn, intersection } from 'lodash';\n\nimport Log from './log';\n\n/**\n * Utility class designed for merging dependencies list with simple validation and duplicate\n * detection.\n *\n * @class\n */\nexport default class DependenciesManager {\n    /**\n     * @param {MeteorDesktop} $                   - context\n     * @param {Object}        defaultDependencies - core dependencies list\n     * @constructor\n     */\n    constructor($, defaultDependencies) {\n        this.log = new Log('dependenciesManager');\n        this.$ = $;\n        this.dependencies = defaultDependencies;\n\n        // Regexes for matching certain types of dependencies version.\n        // https://docs.npmjs.com/files/package.json#dependencies\n        this.regexes = {\n            local: /^(\\.\\.\\/|~\\/|\\.\\/|\\/)/,\n            git: /^git(\\+(ssh|http)s?)?/,\n            github: /^\\w+-?\\w+(?!-)\\//,\n            http: /^https?.+tar\\.gz/,\n            file: /^file:/\n        };\n\n        // Check for commit hashes.\n        const gitCheck = {\n            type: 'regex',\n            regex: /#[a-f0-9]{7,40}/,\n            test: 'match',\n            message: 'git or github link must have a commit hash'\n        };\n\n        // Check for displaying warnings when npm package from local path is used.\n        const localCheck = {\n            onceName: 'localCheck',\n            type: 'warning',\n            message: 'using dependencies from local paths is permitted' +\n            ' but dangerous - read more in README.md'\n        };\n\n        this.checks = {\n            local: localCheck,\n            file: localCheck,\n            git: gitCheck,\n            github: gitCheck,\n            version: {\n                type: 'regex',\n                // Matches all the semver ranges operators, empty strings and `*`.\n                regex: /[\\^|><= ~-]|\\.x|^$|^\\*$/,\n                test: 'do not match',\n                message: 'semver ranges are forbidden, please specify exact version'\n            }\n        };\n    }\n\n    /**\n     * Just a public getter.\n     * @returns {Object}\n     */\n    getDependencies() {\n        return this.dependencies;\n    }\n\n    /**\n     * Returns local dependencies.\n     * @returns {Object}\n     */\n    getLocalDependencies() {\n        return Object\n            .keys(this.dependencies)\n            .filter(\n                dependency =>\n                    this.regexes.local.test(this.dependencies[dependency]) ||\n                    this.regexes.file.test(this.dependencies[dependency])\n            )\n            .reduce(\n                (localDependencies, currentDependency) =>\n                    Object.assign(\n                        localDependencies,\n                        { [currentDependency]: this.dependencies[currentDependency] }\n                    ),\n                {}\n            );\n    }\n\n    /**\n     * Returns remote dependencies.\n     * @returns {Object}\n     */\n    getRemoteDependencies() {\n        return Object\n            .keys(this.dependencies)\n            .filter(\n                dependency =>\n                    !this.regexes.local.test(this.dependencies[dependency]) &&\n                    !this.regexes.file.test(this.dependencies[dependency])\n            )\n            .reduce(\n                (localDependencies, currentDependency) =>\n                    Object.assign(\n                        localDependencies,\n                        { [currentDependency]: this.dependencies[currentDependency] }\n                    ),\n                {}\n            );\n    }\n\n    /**\n     * Merges dependencies into one list.\n     *\n     * @param {string} from         - describes where the dependencies were set\n     * @param {Object} dependencies - dependencies list\n     */\n    mergeDependencies(from, dependencies) {\n        if (this.validateDependenciesVersions(from, dependencies)) {\n            this.detectDuplicatedDependencies(from, dependencies);\n            assignIn(this.dependencies, dependencies);\n        }\n    }\n\n    /**\n     * Detects dependency version type.\n     * @param {string} version - version string of the dependency\n     * @return {string}\n     */\n    detectDependencyVersionType(version) {\n        const type = Object.keys(this.regexes)\n            .find(dependencyType => this.regexes[dependencyType].test(version));\n        return type || 'version';\n    }\n\n    /**\n     * Validates semver and detect ranges.\n     *\n     * @param {string} from         - describes where the dependencies were set\n     * @param {Object} dependencies - dependencies list\n     */\n    validateDependenciesVersions(from, dependencies) {\n        const warningsShown = {};\n        forEach(dependencies, (version, name) => {\n            const type = this.detectDependencyVersionType(version);\n            if (this.checks[type]) {\n                const check = this.checks[type];\n                if (check.type === 'regex') {\n                    const checkResult = check.test === 'match' ?\n                        this.checks[type].regex.test(version) :\n                        !this.checks[type].regex.test(version);\n                    if (!checkResult) {\n                        throw new Error(`dependency ${name}:${version} from ${from} failed version ` +\n                            `check with message: ${this.checks[type].message}`);\n                    }\n                }\n                if (check.type === 'warning' && !warningsShown[check.onceName]) {\n                    warningsShown[check.onceName] = true;\n                    this.log.warn(`dependency ${name}:${version} from ${from} caused a` +\n                        ` warning: ${check.message}`);\n                }\n            }\n        });\n        return true;\n    }\n\n    /**\n     * Detects duplicates.\n     *\n     * @param {string} from         - describes where the dependencies were set\n     * @param {Object} dependencies - dependencies list\n     */\n    detectDuplicatedDependencies(from, dependencies) {\n        const duplicates = intersection(Object.keys(dependencies), Object.keys(this.dependencies));\n        if (duplicates.length > 0) {\n            duplicates.forEach((name) => {\n                if (dependencies[name] !== this.dependencies[name]) {\n                    throw new Error(`While processing dependencies from ${from}, a dependency ` +\n                        `${name}: ${dependencies[name]} was found to be conflicting with a ` +\n                        `dependency (${this.dependencies[name]}) that was already declared in ` +\n                        'other module or it is used in core of the electron app.');\n                }\n            });\n        }\n    }\n}\n"],"mappings":"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"}
\ No newline at end of file
diff --git a/dist/desktop.js b/dist/desktop.js
new file mode 100644
index 00000000..3a5f1cd9
--- /dev/null
+++ b/dist/desktop.js
@@ -0,0 +1,271 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = void 0;
+
+var _runtime = _interopRequireDefault(require("regenerator-runtime/runtime"));
+
+var _shelljs = _interopRequireDefault(require("shelljs"));
+
+var _fs = _interopRequireDefault(require("fs"));
+
+var _path = _interopRequireDefault(require("path"));
+
+var _log = _interopRequireDefault(require("./log"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+// eslint-disable-next-line no-unused-vars
+_shelljs.default.config.fatal = true;
+/**
+ * Checks if the path is empty.
+ * @param {string} searchPath
+ * @returns {boolean}
+ */
+
+function isEmptySync(searchPath) {
+ let stat;
+
+ try {
+ stat = _fs.default.statSync(searchPath);
+ } catch (e) {
+ return true;
+ }
+
+ if (stat.isDirectory()) {
+ const items = _fs.default.readdirSync(searchPath);
+
+ return !items || !items.length;
+ }
+
+ return false;
+}
+/**
+ * Represents the .desktop directory.
+ * @class
+ * @property {desktopSettings} settings
+ */
+
+
+class Desktop {
+ /**
+ * @param {MeteorDesktop} $ - context
+ *
+ * @constructor
+ */
+ constructor($) {
+ this.$ = $;
+ this.log = new _log.default('desktop');
+ this.settings = null;
+ this.dependencies = null;
+ }
+ /**
+ * Tries to read and returns settings.json contents from .desktop dir.
+ *
+ * @returns {desktopSettings|null}
+ */
+
+
+ getSettings() {
+ if (!this.settings) {
+ try {
+ this.settings = JSON.parse(_fs.default.readFileSync(this.$.env.paths.desktop.settings, 'UTF-8'));
+ } catch (e) {
+ this.log.error('error while trying to read \'.desktop/settings.json\': ', e);
+ process.exit(1);
+ }
+ }
+
+ return this.settings;
+ }
+ /**
+ * Returns a version hash representing current .desktop contents.
+ * @returns {string}
+ */
+
+
+ async getHashVersion() {
+ this.log.info('calculating hash version from .desktop contents');
+ const version = await this.$.utils.readFilesAndComputeHash(this.$.env.paths.desktop.root);
+ this.log.verbose(`calculated .desktop hash version is ${version.hash}`);
+ return version.hash;
+ }
+ /**
+ * Tries to read a module.json file from a module at provided path.
+ *
+ * @param {string} modulePath - path to the module dir
+ * @returns {Object}
+ */
+
+
+ getModuleConfig(modulePath) {
+ let moduleConfig = {};
+
+ try {
+ moduleConfig = JSON.parse(_fs.default.readFileSync(_path.default.join(modulePath, 'module.json'), 'UTF-8'));
+ } catch (e) {
+ this.log.error(`error while trying to read 'module.json' from '${modulePath}' module: `, e);
+ process.exit(1);
+ }
+
+ if (!('name' in moduleConfig)) {
+ this.log.error(`no 'name' field defined in 'module.json' in '${modulePath}' module.`);
+ process.exit(1);
+ }
+
+ return moduleConfig;
+ }
+ /**
+ * Scans all modules for module.json and gathers this configuration altogether.
+ *
+ * @returns {[]}
+ */
+
+
+ gatherModuleConfigs() {
+ const configs = [];
+
+ if (!isEmptySync(this.$.env.paths.desktop.modules)) {
+ _shelljs.default.ls('-d', _path.default.join(this.$.env.paths.desktop.modules, '*')).forEach(module => {
+ if (_fs.default.lstatSync(module).isDirectory()) {
+ const moduleConfig = this.getModuleConfig(module);
+ moduleConfig.dirName = _path.default.parse(module).name;
+ configs.push(moduleConfig);
+ }
+ });
+ }
+
+ return configs;
+ }
+ /**
+ * Summarizes all dependencies defined in .desktop.
+ *
+ * @params {Object} settings - settings.json
+ * @params {boolean} checkModules - whether to gather modules dependencies
+ * @params {boolean} refresh - recompute
+ * @returns {{fromSettings: {}, plugins: {}, modules: {}}}
+ */
+
+
+ getDependencies(settings = null, checkModules = true, refresh = false) {
+ if (!refresh && this.dependencies) {
+ return this.dependencies;
+ }
+
+ const dependencies = {
+ fromSettings: {},
+ plugins: {},
+ modules: {}
+ };
+ /** @type {desktopSettings} * */
+
+ const settingsJson = settings || this.getSettings(); // Settings can have a 'dependencies' field.
+
+ if ('dependencies' in settingsJson) {
+ dependencies.fromSettings = settingsJson.dependencies;
+ } // Plugins are also a npm packages.
+
+
+ if ('plugins' in settingsJson) {
+ dependencies.plugins = Object.keys(settingsJson.plugins).reduce((plugins, plugin) => {
+ /* eslint-disable no-param-reassign */
+ if (typeof settingsJson.plugins[plugin] === 'object') {
+ plugins[plugin] = settingsJson.plugins[plugin].version;
+ } else {
+ plugins[plugin] = settingsJson.plugins[plugin];
+ }
+
+ return plugins;
+ }, {});
+ } // Each module can have its own dependencies defined.
+
+
+ const moduleDependencies = {};
+
+ if (checkModules) {
+ const configs = this.gatherModuleConfigs();
+ configs.forEach(moduleConfig => {
+ if (!('dependencies' in moduleConfig)) {
+ moduleConfig.dependencies = {};
+ }
+
+ if (moduleConfig.name in moduleDependencies) {
+ this.log.error(`duplicate name '${moduleConfig.name}' in 'module.json' in ` + `'${moduleConfig.dirName}' - another module already registered the same name.`);
+ process.exit(1);
+ }
+
+ moduleDependencies[moduleConfig.name] = moduleConfig.dependencies;
+ });
+ }
+
+ dependencies.modules = moduleDependencies;
+ this.dependencies = dependencies;
+ return dependencies;
+ }
+ /**
+ * Copies the .desktop scaffold into the meteor app dir.
+ * Adds entry to .meteor/.gitignore.
+ */
+
+
+ scaffold() {
+ this.log.info('creating .desktop scaffold in your project');
+
+ if (this.$.utils.exists(this.$.env.paths.desktop.root)) {
+ this.log.warn('.desktop already exists - delete it if you want a new one to be ' + 'created');
+ return;
+ }
+
+ _shelljs.default.cp('-r', this.$.env.paths.scaffold, this.$.env.paths.desktop.root);
+
+ _shelljs.default.mkdir(this.$.env.paths.desktop.import);
+
+ this.log.info('.desktop directory prepared');
+ }
+ /**
+ * Verifies if all mandatory files are present in the .desktop.
+ *
+ * @returns {boolean}
+ */
+
+
+ check() {
+ this.log.verbose('checking .desktop existence');
+ return !!(this.$.utils.exists(this.$.env.paths.desktop.root) && this.$.utils.exists(this.$.env.paths.desktop.settings) && this.$.utils.exists(this.$.env.paths.desktop.desktop));
+ }
+
+}
+/**
+ * @typedef {Object} desktopSettings
+ * @property {string} name
+ * @property {string} projectName
+ * @property {boolean} devTools
+ * @property {boolean} devtron
+ * @property {boolean} desktopHCP
+ * @property {Object} squirrel
+ * @property {string} squirrel.autoUpdateFeedUrl
+ * @property {Object} squirrel.autoUpdateFeedHeaders
+ * @property {Object} squirrel.autoUpdateCheckOnStart
+ * @property {Object} desktopHCPSettings
+ * @property {boolean} desktopHCPSettings.ignoreCompatibilityVersion
+ * @property {boolean} desktopHCPSettings.blockAppUpdateOnDesktopIncompatibility
+ * @property {number} webAppStartupTimeout
+ * @property {Array} linkPackages
+ * @property {Array} exposedModules
+ * @property {Object} window
+ * @property {Object} windowDev
+ * @property {Object} packageJsonFields
+ * @property {Object} builderOptions
+ * @property {Object} builderCliOptions
+ * @property {Object} packagerOptions
+ * @property {Object} plugins
+ * @property {Object} dependencies
+ * @property {boolean} uglify
+ * @property {string} version
+ * */
+
+
+exports.default = Desktop;
+//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["shell","config","fatal","isEmptySync","searchPath","stat","fs","statSync","e","isDirectory","items","readdirSync","length","Desktop","constructor","$","log","Log","settings","dependencies","getSettings","JSON","parse","readFileSync","env","paths","desktop","error","process","exit","getHashVersion","info","version","utils","readFilesAndComputeHash","root","verbose","hash","getModuleConfig","modulePath","moduleConfig","path","join","gatherModuleConfigs","configs","modules","ls","forEach","module","lstatSync","dirName","name","push","getDependencies","checkModules","refresh","fromSettings","plugins","settingsJson","Object","keys","reduce","plugin","moduleDependencies","scaffold","exists","warn","cp","mkdir","import","check"],"sources":["../lib/desktop.js"],"sourcesContent":["// eslint-disable-next-line no-unused-vars\nimport regeneratorRuntime from 'regenerator-runtime/runtime';\nimport shell from 'shelljs';\nimport fs from 'fs';\nimport path from 'path';\n\nimport Log from './log';\n\nshell.config.fatal = true;\n\n/**\n * Checks if the path is empty.\n * @param {string} searchPath\n * @returns {boolean}\n */\nfunction isEmptySync(searchPath) {\n    let stat;\n    try {\n        stat = fs.statSync(searchPath);\n    } catch (e) {\n        return true;\n    }\n    if (stat.isDirectory()) {\n        const items = fs.readdirSync(searchPath);\n        return !items || !items.length;\n    }\n    return false;\n}\n\n/**\n * Represents the .desktop directory.\n * @class\n * @property {desktopSettings} settings\n */\nexport default class Desktop {\n    /**\n     * @param {MeteorDesktop} $ - context\n     *\n     * @constructor\n     */\n    constructor($) {\n        this.$ = $;\n        this.log = new Log('desktop');\n        this.settings = null;\n        this.dependencies = null;\n    }\n\n    /**\n     * Tries to read and returns settings.json contents from .desktop dir.\n     *\n     * @returns {desktopSettings|null}\n     */\n    getSettings() {\n        if (!this.settings) {\n            try {\n                this.settings = JSON.parse(\n                    fs.readFileSync(this.$.env.paths.desktop.settings, 'UTF-8')\n                );\n            } catch (e) {\n                this.log.error('error while trying to read \\'.desktop/settings.json\\': ', e);\n                process.exit(1);\n            }\n        }\n        return this.settings;\n    }\n\n    /**\n     * Returns a version hash representing current .desktop contents.\n     * @returns {string}\n     */\n    async getHashVersion() {\n        this.log.info('calculating hash version from .desktop contents');\n\n        const version = await this.$.utils.readFilesAndComputeHash(this.$.env.paths.desktop.root);\n\n        this.log.verbose(`calculated .desktop hash version is ${version.hash}`);\n        return version.hash;\n    }\n\n    /**\n     * Tries to read a module.json file from a module at provided path.\n     *\n     * @param {string} modulePath - path to the module dir\n     * @returns {Object}\n     */\n    getModuleConfig(modulePath) {\n        let moduleConfig = {};\n        try {\n            moduleConfig = JSON.parse(\n                fs.readFileSync(path.join(modulePath, 'module.json'), 'UTF-8')\n            );\n        } catch (e) {\n            this.log.error(\n                `error while trying to read 'module.json' from '${modulePath}' module: `,\n                e\n            );\n            process.exit(1);\n        }\n        if (!('name' in moduleConfig)) {\n            this.log.error(`no 'name' field defined in 'module.json' in '${modulePath}' module.`);\n            process.exit(1);\n        }\n        return moduleConfig;\n    }\n\n    /**\n     * Scans all modules for module.json and gathers this configuration altogether.\n     *\n     * @returns {[]}\n     */\n    gatherModuleConfigs() {\n        const configs = [];\n\n        if (!isEmptySync(this.$.env.paths.desktop.modules)) {\n            shell.ls('-d', path.join(this.$.env.paths.desktop.modules, '*')).forEach(\n                (module) => {\n                    if (fs.lstatSync(module).isDirectory()) {\n                        const moduleConfig = this.getModuleConfig(module);\n                        moduleConfig.dirName = path.parse(module).name;\n                        configs.push(moduleConfig);\n                    }\n                }\n            );\n        }\n        return configs;\n    }\n\n    /**\n     * Summarizes all dependencies defined in .desktop.\n     *\n     * @params {Object} settings      - settings.json\n     * @params {boolean} checkModules - whether to gather modules dependencies\n     * @params {boolean} refresh      - recompute\n     * @returns {{fromSettings: {}, plugins: {}, modules: {}}}\n     */\n    getDependencies(settings = null, checkModules = true, refresh = false) {\n        if (!refresh && this.dependencies) {\n            return this.dependencies;\n        }\n\n        const dependencies = {\n            fromSettings: {},\n            plugins: {},\n            modules: {}\n        };\n        /** @type {desktopSettings} * */\n        const settingsJson = settings || this.getSettings();\n\n        // Settings can have a 'dependencies' field.\n        if ('dependencies' in settingsJson) {\n            dependencies.fromSettings = settingsJson.dependencies;\n        }\n\n        // Plugins are also a npm packages.\n        if ('plugins' in settingsJson) {\n            dependencies.plugins = Object.keys(settingsJson.plugins).reduce((plugins, plugin) => {\n                /* eslint-disable no-param-reassign */\n                if (typeof settingsJson.plugins[plugin] === 'object') {\n                    plugins[plugin] = settingsJson.plugins[plugin].version;\n                } else {\n                    plugins[plugin] = settingsJson.plugins[plugin];\n                }\n                return plugins;\n            }, {});\n        }\n\n        // Each module can have its own dependencies defined.\n        const moduleDependencies = {};\n        if (checkModules) {\n            const configs = this.gatherModuleConfigs();\n\n            configs.forEach(\n                (moduleConfig) => {\n                    if (!('dependencies' in moduleConfig)) {\n                        moduleConfig.dependencies = {};\n                    }\n                    if (moduleConfig.name in moduleDependencies) {\n                        this.log.error(`duplicate name '${moduleConfig.name}' in 'module.json' in ` +\n                            `'${moduleConfig.dirName}' - another module already registered the same name.`);\n                        process.exit(1);\n                    }\n                    moduleDependencies[moduleConfig.name] = moduleConfig.dependencies;\n                }\n            );\n        }\n\n        dependencies.modules = moduleDependencies;\n        this.dependencies = dependencies;\n        return dependencies;\n    }\n\n    /**\n     * Copies the .desktop scaffold into the meteor app dir.\n     * Adds entry to .meteor/.gitignore.\n     */\n    scaffold() {\n        this.log.info('creating .desktop scaffold in your project');\n\n        if (this.$.utils.exists(this.$.env.paths.desktop.root)) {\n            this.log.warn('.desktop already exists - delete it if you want a new one to be ' +\n                'created');\n            return;\n        }\n\n        shell.cp('-r', this.$.env.paths.scaffold, this.$.env.paths.desktop.root);\n        shell.mkdir(this.$.env.paths.desktop.import);\n        this.log.info('.desktop directory prepared');\n    }\n\n    /**\n     * Verifies if all mandatory files are present in the .desktop.\n     *\n     * @returns {boolean}\n     */\n    check() {\n        this.log.verbose('checking .desktop existence');\n        return !!(this.$.utils.exists(this.$.env.paths.desktop.root) &&\n            this.$.utils.exists(this.$.env.paths.desktop.settings) &&\n            this.$.utils.exists(this.$.env.paths.desktop.desktop));\n    }\n}\n\n/**\n * @typedef {Object} desktopSettings\n * @property {string} name\n * @property {string} projectName\n * @property {boolean} devTools\n * @property {boolean} devtron\n * @property {boolean} desktopHCP\n * @property {Object} squirrel\n * @property {string} squirrel.autoUpdateFeedUrl\n * @property {Object} squirrel.autoUpdateFeedHeaders\n * @property {Object} squirrel.autoUpdateCheckOnStart\n * @property {Object} desktopHCPSettings\n * @property {boolean} desktopHCPSettings.ignoreCompatibilityVersion\n * @property {boolean} desktopHCPSettings.blockAppUpdateOnDesktopIncompatibility\n * @property {number} webAppStartupTimeout\n * @property {Array} linkPackages\n * @property {Array} exposedModules\n * @property {Object} window\n * @property {Object} windowDev\n * @property {Object} packageJsonFields\n * @property {Object} builderOptions\n * @property {Object} builderCliOptions\n * @property {Object} packagerOptions\n * @property {Object} plugins\n * @property {Object} dependencies\n * @property {boolean} uglify\n * @property {string} version\n * */\n"],"mappings":"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"}
\ No newline at end of file
diff --git a/dist/electron.js b/dist/electron.js
new file mode 100644
index 00000000..4b4a584d
--- /dev/null
+++ b/dist/electron.js
@@ -0,0 +1,61 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = void 0;
+
+var _runtime = _interopRequireDefault(require("regenerator-runtime/runtime"));
+
+var _crossSpawn = _interopRequireDefault(require("cross-spawn"));
+
+var _log = _interopRequireDefault(require("./log"));
+
+var _defaultDependencies = _interopRequireDefault(require("./defaultDependencies"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Simple Electron runner. Runs the project with the bin provided by the 'electron' package.
+ * @class
+ */
+class Electron {
+ constructor($) {
+ this.log = new _log.default('electron');
+ this.$ = $;
+ }
+
+ async init() {
+ this.electron = await this.$.getDependency('electron', _defaultDependencies.default.electron);
+ }
+
+ run() {
+ // Until: https://github.com/electron-userland/electron-prebuilt/pull/118
+ const {
+ env
+ } = process;
+ env.ELECTRON_ENV = 'development';
+ const cmd = [];
+
+ if (this.$.env.options.debug) {
+ cmd.push('--debug=5858');
+ }
+
+ cmd.push('.');
+ const child = (0, _crossSpawn.default)(this.electron.dependency, cmd, {
+ cwd: this.$.env.paths.electronApp.root,
+ env
+ }); // TODO: check if we can configure piping in spawn options
+
+ child.stdout.on('data', chunk => {
+ process.stdout.write(chunk);
+ });
+ child.stderr.on('data', chunk => {
+ process.stderr.write(chunk);
+ });
+ }
+
+}
+
+exports.default = Electron;
+//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJFbGVjdHJvbiIsImNvbnN0cnVjdG9yIiwiJCIsImxvZyIsIkxvZyIsImluaXQiLCJlbGVjdHJvbiIsImdldERlcGVuZGVuY3kiLCJkZWZhdWx0RGVwZW5kZW5jaWVzIiwicnVuIiwiZW52IiwicHJvY2VzcyIsIkVMRUNUUk9OX0VOViIsImNtZCIsIm9wdGlvbnMiLCJkZWJ1ZyIsInB1c2giLCJjaGlsZCIsInNwYXduIiwiZGVwZW5kZW5jeSIsImN3ZCIsInBhdGhzIiwiZWxlY3Ryb25BcHAiLCJyb290Iiwic3Rkb3V0Iiwib24iLCJjaHVuayIsIndyaXRlIiwic3RkZXJyIl0sInNvdXJjZXMiOlsiLi4vbGliL2VsZWN0cm9uLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCByZWdlbmVyYXRvclJ1bnRpbWUgZnJvbSAncmVnZW5lcmF0b3ItcnVudGltZS9ydW50aW1lJztcbmltcG9ydCBzcGF3biBmcm9tICdjcm9zcy1zcGF3bic7XG5cbmltcG9ydCBMb2cgZnJvbSAnLi9sb2cnO1xuaW1wb3J0IGRlZmF1bHREZXBlbmRlbmNpZXMgZnJvbSAnLi9kZWZhdWx0RGVwZW5kZW5jaWVzJztcblxuLyoqXG4gKiBTaW1wbGUgRWxlY3Ryb24gcnVubmVyLiBSdW5zIHRoZSBwcm9qZWN0IHdpdGggdGhlIGJpbiBwcm92aWRlZCBieSB0aGUgJ2VsZWN0cm9uJyBwYWNrYWdlLlxuICogQGNsYXNzXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIEVsZWN0cm9uIHtcbiAgICBjb25zdHJ1Y3RvcigkKSB7XG4gICAgICAgIHRoaXMubG9nID0gbmV3IExvZygnZWxlY3Ryb24nKTtcbiAgICAgICAgdGhpcy4kID0gJDtcbiAgICB9XG5cbiAgICBhc3luYyBpbml0KCkge1xuICAgICAgICB0aGlzLmVsZWN0cm9uID0gYXdhaXQgdGhpcy4kLmdldERlcGVuZGVuY3koJ2VsZWN0cm9uJywgZGVmYXVsdERlcGVuZGVuY2llcy5lbGVjdHJvbik7XG4gICAgfVxuXG4gICAgcnVuKCkge1xuICAgICAgICAvLyBVbnRpbDogaHR0cHM6Ly9naXRodWIuY29tL2VsZWN0cm9uLXVzZXJsYW5kL2VsZWN0cm9uLXByZWJ1aWx0L3B1bGwvMTE4XG4gICAgICAgIGNvbnN0IHsgZW52IH0gPSBwcm9jZXNzO1xuICAgICAgICBlbnYuRUxFQ1RST05fRU5WID0gJ2RldmVsb3BtZW50JztcblxuICAgICAgICBjb25zdCBjbWQgPSBbXTtcblxuICAgICAgICBpZiAodGhpcy4kLmVudi5vcHRpb25zLmRlYnVnKSB7XG4gICAgICAgICAgICBjbWQucHVzaCgnLS1kZWJ1Zz01ODU4Jyk7XG4gICAgICAgIH1cblxuICAgICAgICBjbWQucHVzaCgnLicpO1xuXG4gICAgICAgIGNvbnN0IGNoaWxkID0gc3Bhd24odGhpcy5lbGVjdHJvbi5kZXBlbmRlbmN5LCBjbWQsIHtcbiAgICAgICAgICAgIGN3ZDogdGhpcy4kLmVudi5wYXRocy5lbGVjdHJvbkFwcC5yb290LFxuICAgICAgICAgICAgZW52XG4gICAgICAgIH0pO1xuXG4gICAgICAgIC8vIFRPRE86IGNoZWNrIGlmIHdlIGNhbiBjb25maWd1cmUgcGlwaW5nIGluIHNwYXduIG9wdGlvbnNcbiAgICAgICAgY2hpbGQuc3Rkb3V0Lm9uKCdkYXRhJywgKGNodW5rKSA9PiB7XG4gICAgICAgICAgICBwcm9jZXNzLnN0ZG91dC53cml0ZShjaHVuayk7XG4gICAgICAgIH0pO1xuICAgICAgICBjaGlsZC5zdGRlcnIub24oJ2RhdGEnLCAoY2h1bmspID0+IHtcbiAgICAgICAgICAgIHByb2Nlc3Muc3RkZXJyLndyaXRlKGNodW5rKTtcbiAgICAgICAgfSk7XG4gICAgfVxufVxuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7O0FBQ0E7O0FBRUE7O0FBQ0E7Ozs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNlLE1BQU1BLFFBQU4sQ0FBZTtFQUMxQkMsV0FBVyxDQUFDQyxDQUFELEVBQUk7SUFDWCxLQUFLQyxHQUFMLEdBQVcsSUFBSUMsWUFBSixDQUFRLFVBQVIsQ0FBWDtJQUNBLEtBQUtGLENBQUwsR0FBU0EsQ0FBVDtFQUNIOztFQUVTLE1BQUpHLElBQUksR0FBRztJQUNULEtBQUtDLFFBQUwsR0FBZ0IsTUFBTSxLQUFLSixDQUFMLENBQU9LLGFBQVAsQ0FBcUIsVUFBckIsRUFBaUNDLDRCQUFBLENBQW9CRixRQUFyRCxDQUF0QjtFQUNIOztFQUVERyxHQUFHLEdBQUc7SUFDRjtJQUNBLE1BQU07TUFBRUM7SUFBRixJQUFVQyxPQUFoQjtJQUNBRCxHQUFHLENBQUNFLFlBQUosR0FBbUIsYUFBbkI7SUFFQSxNQUFNQyxHQUFHLEdBQUcsRUFBWjs7SUFFQSxJQUFJLEtBQUtYLENBQUwsQ0FBT1EsR0FBUCxDQUFXSSxPQUFYLENBQW1CQyxLQUF2QixFQUE4QjtNQUMxQkYsR0FBRyxDQUFDRyxJQUFKLENBQVMsY0FBVDtJQUNIOztJQUVESCxHQUFHLENBQUNHLElBQUosQ0FBUyxHQUFUO0lBRUEsTUFBTUMsS0FBSyxHQUFHLElBQUFDLG1CQUFBLEVBQU0sS0FBS1osUUFBTCxDQUFjYSxVQUFwQixFQUFnQ04sR0FBaEMsRUFBcUM7TUFDL0NPLEdBQUcsRUFBRSxLQUFLbEIsQ0FBTCxDQUFPUSxHQUFQLENBQVdXLEtBQVgsQ0FBaUJDLFdBQWpCLENBQTZCQyxJQURhO01BRS9DYjtJQUYrQyxDQUFyQyxDQUFkLENBYkUsQ0FrQkY7O0lBQ0FPLEtBQUssQ0FBQ08sTUFBTixDQUFhQyxFQUFiLENBQWdCLE1BQWhCLEVBQXlCQyxLQUFELElBQVc7TUFDL0JmLE9BQU8sQ0FBQ2EsTUFBUixDQUFlRyxLQUFmLENBQXFCRCxLQUFyQjtJQUNILENBRkQ7SUFHQVQsS0FBSyxDQUFDVyxNQUFOLENBQWFILEVBQWIsQ0FBZ0IsTUFBaEIsRUFBeUJDLEtBQUQsSUFBVztNQUMvQmYsT0FBTyxDQUFDaUIsTUFBUixDQUFlRCxLQUFmLENBQXFCRCxLQUFyQjtJQUNILENBRkQ7RUFHSDs7QUFuQ3lCIn0=
\ No newline at end of file
diff --git a/dist/electronApp.js b/dist/electronApp.js
new file mode 100644
index 00000000..6e7966c3
--- /dev/null
+++ b/dist/electronApp.js
@@ -0,0 +1,876 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = void 0;
+
+var _runtime = _interopRequireDefault(require("regenerator-runtime/runtime"));
+
+var _asar = _interopRequireDefault(require("@electron/asar"));
+
+var _assignIn = _interopRequireDefault(require("lodash/assignIn"));
+
+var _lodash = _interopRequireDefault(require("lodash"));
+
+var _installLocal = require("install-local");
+
+var _core = require("@babel/core");
+
+var _crypto = _interopRequireDefault(require("crypto"));
+
+var _del = _interopRequireDefault(require("del"));
+
+var _presetEnv = _interopRequireDefault(require("@babel/preset-env"));
+
+var _fs = _interopRequireDefault(require("fs"));
+
+var _path = _interopRequireDefault(require("path"));
+
+var _shelljs = _interopRequireDefault(require("shelljs"));
+
+var _semver = _interopRequireDefault(require("semver"));
+
+var _terser = _interopRequireDefault(require("terser"));
+
+var _log = _interopRequireDefault(require("./log"));
+
+var _electronAppScaffold = _interopRequireDefault(require("./electronAppScaffold"));
+
+var _dependenciesManager = _interopRequireDefault(require("./dependenciesManager"));
+
+var _binaryModulesDetector = _interopRequireDefault(require("./binaryModulesDetector"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+// eslint-disable-next-line no-unused-vars
+_shelljs.default.config.fatal = true;
+/**
+ * Represents the .desktop dir scaffold.
+ * @class
+ */
+
+class ElectronApp {
+ /**
+ * @param {MeteorDesktop} $ - context
+ * @constructor
+ */
+ constructor($) {
+ this.log = new _log.default('electronApp');
+ this.scaffold = new _electronAppScaffold.default($);
+ this.depsManager = new _dependenciesManager.default($, this.scaffold.getDefaultPackageJson().dependencies);
+ this.$ = $;
+ this.meteorApp = this.$.meteorApp;
+ this.packageJson = null;
+ this.version = null;
+ this.compatibilityVersion = null;
+ this.deprectatedPlugins = ['meteor-desktop-localstorage'];
+ }
+ /**
+ * Makes an app.asar from the skeleton app.
+ * @property {Array} excludeFromDel - list of paths to exclude from deleting
+ * @returns {Promise}
+ */
+
+
+ packSkeletonToAsar(excludeFromDel = []) {
+ this.log.info('packing skeleton app and node_modules to asar archive');
+ return new Promise(resolve => {
+ const extract = this.getModulesToExtract(); // We want to pack skeleton app and node_modules together, so we need to temporarily
+ // move node_modules to app dir.
+
+ this.log.debug('moving node_modules to app dir');
+
+ _fs.default.renameSync(this.$.env.paths.electronApp.nodeModules, _path.default.join(this.$.env.paths.electronApp.appRoot, 'node_modules'));
+
+ let extracted = false;
+ extracted = this.extractModules(extract);
+ this.log.debug('packing');
+
+ _asar.default.createPackage(this.$.env.paths.electronApp.appRoot, this.$.env.paths.electronApp.appAsar).then(() => {
+ // Lets move the node_modules back.
+ this.log.debug('moving node_modules back from app dir');
+
+ _shelljs.default.mv(_path.default.join(this.$.env.paths.electronApp.appRoot, 'node_modules'), this.$.env.paths.electronApp.nodeModules);
+
+ if (extracted) {
+ // We need to create a full node modules back. In other words we want
+ // the extracted modules back.
+ extract.forEach(module => _shelljs.default.cp('-rf', _path.default.join(this.$.env.paths.electronApp.extractedNodeModules, module), _path.default.join(this.$.env.paths.electronApp.nodeModules, module))); // Get the .bin back.
+
+ if (this.$.utils.exists(this.$.env.paths.electronApp.extractedNodeModulesBin)) {
+ _shelljs.default.cp(_path.default.join(this.$.env.paths.electronApp.extractedNodeModulesBin, '*'), _path.default.join(this.$.env.paths.electronApp.nodeModules, '.bin'));
+ }
+ }
+
+ this.log.debug('deleting source files');
+ const exclude = [this.$.env.paths.electronApp.nodeModules].concat([this.$.env.paths.electronApp.appAsar, this.$.env.paths.electronApp.packageJson], excludeFromDel);
+
+ _del.default.sync([`${this.$.env.paths.electronApp.root}${_path.default.sep}*`].concat(exclude.map(pathToExclude => `!${pathToExclude}`)), {
+ force: true
+ });
+
+ resolve();
+ });
+ });
+ }
+ /**
+ * Moves specified node modules to a separate directory.
+ * @param {Array} extract
+ * @returns {boolean}
+ */
+
+
+ extractModules(extract) {
+ const ext = ['.js', '.bat', '.sh', '.cmd', ''];
+
+ if (extract.length > 0) {
+ if (this.$.utils.exists(this.$.env.paths.electronApp.extractedNodeModules)) {
+ _shelljs.default.rm('-rf', this.$.env.paths.electronApp.extractedNodeModules);
+ }
+
+ _fs.default.mkdirSync(this.$.env.paths.electronApp.extractedNodeModules);
+
+ _fs.default.mkdirSync(this.$.env.paths.electronApp.extractedNodeModulesBin);
+
+ extract.forEach(module => {
+ _fs.default.renameSync(_path.default.join(this.$.env.paths.electronApp.appRoot, 'node_modules', module), _path.default.join(this.$.env.paths.electronApp.extractedNodeModules, module)); // Move bins.
+
+
+ this.extractBin(module, ext);
+ });
+ return true;
+ }
+
+ return false;
+ }
+ /**
+ * Extracts the bin files associated with a certain node modules.
+ *
+ * @param module
+ * @param ext
+ */
+
+
+ extractBin(module, ext) {
+ let packageJson;
+
+ try {
+ packageJson = JSON.parse(_fs.default.readFileSync(_path.default.join(this.$.env.paths.electronApp.extractedNodeModules, module, 'package.json'), 'utf8'));
+ } catch (e) {
+ packageJson = {};
+ }
+
+ const bins = 'bin' in packageJson && typeof packageJson.bin === 'object' ? Object.keys(packageJson.bin) : [];
+
+ if (bins.length > 0) {
+ bins.forEach(bin => {
+ ext.forEach(extension => {
+ const binFilePath = _path.default.join(this.$.env.paths.electronApp.appRoot, 'node_modules', '.bin', `${bin}${extension}`);
+
+ if (this.$.utils.exists(binFilePath) || this.$.utils.symlinkExists(binFilePath)) {
+ _fs.default.renameSync(binFilePath, _path.default.join(this.$.env.paths.electronApp.extractedNodeModulesBin, `${bin}${extension}`));
+ }
+ });
+ });
+ }
+ }
+ /**
+ * Merges the `extract` field with automatically detected modules.
+ */
+
+
+ getModulesToExtract() {
+ const binaryModulesDetector = new _binaryModulesDetector.default(this.$.env.paths.electronApp.nodeModules);
+ const toBeExtracted = binaryModulesDetector.detect();
+ let {
+ extract
+ } = this.$.desktop.getSettings();
+
+ if (!Array.isArray(extract)) {
+ extract = [];
+ }
+
+ const merge = {};
+ toBeExtracted.concat(extract).forEach(module => {
+ merge[module] = true;
+ });
+ extract = Object.keys(merge);
+
+ if (extract.length > 0) {
+ this.log.verbose(`resultant modules to extract list is: ${extract.join(', ')}`);
+ }
+
+ return extract;
+ }
+ /**
+ * Calculates a md5 from all dependencies.
+ */
+
+
+ calculateCompatibilityVersion() {
+ this.log.verbose('calculating compatibility version');
+ const settings = this.$.desktop.getSettings();
+
+ if ('desktopHCPCompatibilityVersion' in settings) {
+ this.compatibilityVersion = `${settings.desktopHCPCompatibilityVersion}`;
+ this.log.warn(`compatibility version overridden to ${this.compatibilityVersion}`);
+ return;
+ }
+
+ const md5 = _crypto.default.createHash('md5');
+
+ let dependencies = this.depsManager.getDependencies();
+ const dependenciesSorted = Object.keys(dependencies).sort();
+ dependencies = dependenciesSorted.map(dependency => `${dependency}:${dependencies[dependency]}`);
+ const mainCompatibilityVersion = this.$.getVersion().split('.');
+ this.log.debug('meteor-desktop compatibility version is ', `${mainCompatibilityVersion[0]}`);
+ dependencies.push(`meteor-desktop:${mainCompatibilityVersion[0]}`);
+ const desktopCompatibilityVersion = settings.version.split('.')[0];
+ this.log.debug('.desktop compatibility version is ', desktopCompatibilityVersion);
+ dependencies.push(`desktop-app:${desktopCompatibilityVersion}`);
+
+ if (process.env.METEOR_DESKTOP_DEBUG_DESKTOP_COMPATIBILITY_VERSION || process.env.METEOR_DESKTOP_DEBUG) {
+ this.log.debug(`compatibility version calculated from ${JSON.stringify(dependencies)}`);
+ }
+
+ md5.update(JSON.stringify(dependencies));
+ this.compatibilityVersion = md5.digest('hex');
+ }
+
+ async init() {
+ try {
+ await this.$.electron.init();
+ await this.$.electronBuilder.init();
+ } catch (e) {
+ this.log.warn('error occurred while initialising electron and electron-builder integration', e);
+ process.exit(1);
+ }
+ }
+ /**
+ * Runs all necessary tasks to build the desktopified app.
+ */
+
+
+ async build(run = false) {
+ // TODO: refactor to a task runner
+ this.log.info('scaffolding');
+
+ if (!this.$.desktop.check()) {
+ if (!this.$.env.options.scaffold) {
+ this.log.error('seems that you do not have a .desktop dir in your project or it is' + ' corrupted. Run \'npm run desktop -- init\' to get a new one.'); // Do not fail, so that npm will not print his error stuff to console.
+
+ process.exit(0);
+ } else {
+ this.$.desktop.scaffold();
+ this.$.meteorApp.updateGitIgnore();
+ }
+ }
+
+ await this.init();
+
+ try {
+ this.$.meteorApp.updateGitIgnore();
+ } catch (e) {
+ this.log.warn(`error occurred while adding ${this.$.env.paths.electronApp.rootName}` + 'to .gitignore: ', e);
+ }
+
+ try {
+ await this.$.meteorApp.removeDeprecatedPackages();
+ } catch (e) {
+ this.log.error('error while removing deprecated packages: ', e);
+ process.exit(1);
+ }
+
+ try {
+ await this.$.meteorApp.ensureDesktopHCPPackages();
+ } catch (e) {
+ this.log.error('error while checking for required packages: ', e);
+ process.exit(1);
+ }
+
+ try {
+ await this.scaffold.make();
+ } catch (e) {
+ this.log.error('error while scaffolding: ', e);
+ process.exit(1);
+ }
+
+ try {
+ const fileName = '.npmrc';
+ const dirName = '.meteor/desktop-build';
+
+ if (_fs.default.existsSync(dirName) && _fs.default.existsSync(fileName)) {
+ _fs.default.copyFileSync(fileName, `${dirName}/${fileName}`);
+ }
+ } catch (e) {
+ this.log.warn('error while copying .npmrc', e);
+ }
+
+ try {
+ await this.exposeElectronModules();
+ } catch (e) {
+ this.log.error('error while exposing electron modules: ', e);
+ process.exit(1);
+ }
+
+ try {
+ this.updatePackageJsonFields();
+ } catch (e) {
+ this.log.error('error while updating package.json: ', e);
+ }
+
+ try {
+ this.updateDependenciesList();
+ } catch (e) {
+ this.log.error('error while merging dependencies list: ', e);
+ }
+
+ try {
+ this.calculateCompatibilityVersion();
+ } catch (e) {
+ this.log.error('error while calculating compatibility version: ', e);
+ process.exit(1);
+ }
+
+ try {
+ await this.handleTemporaryNodeModules();
+ } catch (e) {
+ this.log.error('error occurred while handling temporary node_modules: ', e);
+ process.exit(1);
+ }
+
+ let nodeModulesRemoved;
+
+ try {
+ nodeModulesRemoved = await this.handleStateOfNodeModules();
+ } catch (e) {
+ this.log.error('error occurred while clearing node_modules: ', e);
+ process.exit(1);
+ }
+
+ try {
+ await this.rebuildDeps(true);
+ } catch (e) {
+ this.log.error('error occurred while installing node_modules: ', e);
+ process.exit(1);
+ }
+
+ if (!nodeModulesRemoved) {
+ try {
+ await this.rebuildDeps();
+ } catch (e) {
+ this.log.error('error occurred while rebuilding native node modules: ', e);
+ process.exit(1);
+ }
+ }
+
+ try {
+ await this.linkNpmPackages();
+ } catch (e) {
+ this.log.error(`linking packages failed: ${e}`);
+ process.exit(1);
+ }
+
+ try {
+ await this.installLocalNodeModules();
+ } catch (e) {
+ this.log.error('error occurred while installing local node modules: ', e);
+ process.exit(1);
+ }
+
+ try {
+ await this.ensureMeteorDependencies();
+ } catch (e) {
+ this.log.error('error occurred while ensuring meteor dependencies are installed: ', e);
+ process.exit(1);
+ }
+
+ if (this.$.env.isProductionBuild()) {
+ try {
+ await this.packSkeletonToAsar();
+ } catch (e) {
+ this.log.error('error while packing skeleton to asar: ', e);
+ process.exit(1);
+ }
+ } // TODO: find a way to avoid copying .desktop to a temp location
+
+
+ try {
+ this.copyDesktopToDesktopTemp();
+ } catch (e) {
+ this.log.error('error while copying .desktop to a temporary location: ', e);
+ process.exit(1);
+ }
+
+ try {
+ await this.updateSettingsJsonFields();
+ } catch (e) {
+ this.log.error('error while updating settings.json: ', e);
+ process.exit(1);
+ }
+
+ try {
+ await this.excludeFilesFromArchive();
+ } catch (e) {
+ this.log.error('error while excluding files from packing to asar: ', e);
+ process.exit(1);
+ }
+
+ try {
+ await this.transpileAndMinify();
+ } catch (e) {
+ this.log.error('error while transpiling or minifying: ', e);
+ }
+
+ try {
+ await this.packDesktopToAsar();
+ } catch (e) {
+ this.log.error('error occurred while packing .desktop to asar: ', e);
+ process.exit(1);
+ }
+
+ try {
+ await this.getMeteorClientBuild();
+ } catch (e) {
+ this.log.error('error occurred during getting meteor mobile build: ', e);
+ }
+
+ if (run) {
+ this.log.info('running');
+ this.$.electron.run();
+ } else {
+ this.log.info('built');
+ }
+ }
+ /**
+ * Copies the `exposedModules` setting from `settings.json` into `preload.js` modifying its code
+ * so that the script will have it hardcoded.
+ */
+
+
+ exposeElectronModules() {
+ const {
+ exposedModules
+ } = this.$.desktop.getSettings();
+
+ if (exposedModules && Array.isArray(exposedModules) && exposedModules.length > 0) {
+ let preload = _fs.default.readFileSync(this.$.env.paths.electronApp.preload, 'utf8');
+
+ const modules = this.$.desktop.getSettings().exposedModules.reduce( // eslint-disable-next-line no-return-assign,no-param-reassign
+ (prev, module) => (prev += `'${module}', `, prev), '');
+ preload = preload.replace('const exposedModules = [', `const exposedModules = [${modules}`);
+
+ _fs.default.writeFileSync(this.$.env.paths.electronApp.preload, preload);
+ }
+ }
+ /**
+ * Ensures all required dependencies are added to the Meteor project.
+ * @returns {Promise.}
+ */
+
+
+ async ensureMeteorDependencies() {
+ let packages = [];
+ const packagesWithVersion = [];
+ let plugins = 'plugins [';
+ Object.keys(this.$.desktop.getDependencies().plugins).forEach(plugin => {
+ // Read package.json of the plugin.
+ const packageJson = JSON.parse(_fs.default.readFileSync(_path.default.join(this.$.env.paths.electronApp.nodeModules, plugin, 'package.json'), 'utf8'));
+
+ if ('meteorDependencies' in packageJson && typeof packageJson.meteorDependencies === 'object') {
+ plugins += `${plugin}, `;
+ packages.unshift(...Object.keys(packageJson.meteorDependencies));
+ packagesWithVersion.unshift(...packages.map(packageName => {
+ if (packageJson.meteorDependencies[packageName] === '@version') {
+ return `${packageName}@${packageJson.version}`;
+ }
+
+ return `${packageName}@${packageJson.meteorDependencies[packageName]}`;
+ }));
+ }
+ });
+ const packagesCount = packages.length;
+ packages = packages.filter(value => !this.deprectatedPlugins.includes(value));
+
+ if (packagesCount !== packages.length) {
+ this.log.warn('you have some deprecated meteor desktop plugins in your settings, please remove ' + `them (deprecated plugins: ${this.deprectatedPlugins.join(', ')})`);
+ }
+
+ if (packages.length > 0) {
+ plugins = `${plugins.substr(0, plugins.length - 2)}]`;
+
+ try {
+ await this.$.meteorApp.meteorManager.ensurePackages(packages, packagesWithVersion, plugins);
+ } catch (e) {
+ throw new Error(e);
+ }
+ }
+ }
+ /**
+ * Builds meteor app.
+ */
+
+
+ async getMeteorClientBuild() {
+ await this.$.meteorApp.build();
+ }
+ /**
+ * Removes node_modules if needed.
+ * @returns {Promise}
+ */
+
+
+ async handleStateOfNodeModules() {
+ if (this.$.env.isProductionBuild() || this.$.env.options.ia32) {
+ if (!this.$.env.isProductionBuild()) {
+ this.log.info('clearing node_modules because we need to have it clear for ia32 rebuild');
+ } else {
+ this.log.info('clearing node_modules because this is a production build');
+ }
+
+ try {
+ await this.$.utils.rmWithRetries('-rf', this.$.env.paths.electronApp.nodeModules);
+ } catch (e) {
+ throw new Error(e);
+ }
+
+ return true;
+ }
+
+ return false;
+ }
+ /**
+ * If there is a temporary node_modules folder and no node_modules folder, we will
+ * restore it, as it might be a leftover from an interrupted flow.
+ * @returns {Promise}
+ */
+
+
+ async handleTemporaryNodeModules() {
+ if (this.$.utils.exists(this.$.env.paths.electronApp.tmpNodeModules)) {
+ if (!this.$.utils.exists(this.$.env.paths.electronApp.nodeModules)) {
+ this.log.debug('moving temp node_modules back');
+
+ _shelljs.default.mv(this.$.env.paths.electronApp.tmpNodeModules, this.$.env.paths.electronApp.nodeModules);
+ } else {
+ // If there is a node_modules folder, we should clear the temporary one.
+ this.log.debug('clearing temp node_modules because new one is already created');
+
+ try {
+ await this.$.utils.rmWithRetries('-rf', this.$.env.paths.electronApp.tmpNodeModules);
+ } catch (e) {
+ throw new Error(e);
+ }
+ }
+ }
+ }
+ /**
+ * Runs npm link for every package specified in settings.json->linkPackages.
+ */
+
+
+ async linkNpmPackages() {
+ if (this.$.env.isProductionBuild()) {
+ return;
+ }
+
+ const settings = this.$.desktop.getSettings();
+ const promises = [];
+
+ if ('linkPackages' in this.$.desktop.getSettings()) {
+ if (Array.isArray(settings.linkPackages)) {
+ settings.linkPackages.forEach(packageName => promises.push(this.$.meteorApp.runNpm(['link', packageName], undefined, this.$.env.paths.electronApp.root)));
+ }
+ }
+
+ await Promise.all(promises);
+ }
+ /**
+ * Runs npm in the electron app to get the dependencies installed.
+ * @returns {Promise}
+ */
+
+
+ async ensureDeps() {
+ this.log.info('installing dependencies');
+
+ if (this.$.utils.exists(this.$.env.paths.electronApp.nodeModules)) {
+ this.log.debug('running npm prune to wipe unneeded dependencies');
+
+ try {
+ await this.runNpm(['prune']);
+ } catch (e) {
+ throw new Error(e);
+ }
+ }
+
+ try {
+ await this.runNpm(['install'], this.$.env.stdio);
+ } catch (e) {
+ throw new Error(e);
+ }
+ }
+ /**
+ * Warns if plugins version are outdated in compare to the newest scaffold.
+ * @param {Object} pluginsVersions - current plugins versions from settings.json
+ */
+
+
+ checkPluginsVersion(pluginsVersions) {
+ const settingsJson = JSON.parse(_fs.default.readFileSync(_path.default.join(this.$.env.paths.scaffold, 'settings.json')));
+ const scaffoldPluginsVersion = this.$.desktop.getDependencies(settingsJson, false).plugins;
+ Object.keys(pluginsVersions).forEach(pluginName => {
+ if (pluginName in scaffoldPluginsVersion && scaffoldPluginsVersion[pluginName] !== pluginsVersions[pluginName] && _semver.default.lt(pluginsVersions[pluginName], scaffoldPluginsVersion[pluginName])) {
+ this.log.warn(`you are using outdated version ${pluginsVersions[pluginName]} of ` + `${pluginName}, the suggested version to use is ` + `${scaffoldPluginsVersion[pluginName]}`);
+ }
+ });
+ }
+ /**
+ * Merges core dependency list with the dependencies from .desktop.
+ */
+
+
+ updateDependenciesList() {
+ this.log.info('updating list of package.json\'s dependencies');
+ const desktopDependencies = this.$.desktop.getDependencies();
+ this.checkPluginsVersion(desktopDependencies.plugins);
+ this.log.debug('merging settings.json[dependencies]');
+ this.depsManager.mergeDependencies('settings.json[dependencies]', desktopDependencies.fromSettings);
+ this.log.debug('merging settings.json[plugins]');
+ this.depsManager.mergeDependencies('settings.json[plugins]', desktopDependencies.plugins);
+ this.log.debug('merging dependencies from modules');
+ Object.keys(desktopDependencies.modules).forEach(module => this.depsManager.mergeDependencies(`module[${module}]`, desktopDependencies.modules[module]));
+ this.packageJson.dependencies = this.depsManager.getRemoteDependencies();
+ this.packageJson.localDependencies = this.depsManager.getLocalDependencies();
+ this.log.debug('writing updated package.json');
+
+ _fs.default.writeFileSync(this.$.env.paths.electronApp.packageJson, JSON.stringify(this.packageJson, null, 2));
+ }
+ /**
+ * Install node modules from local paths using local-install.
+ *
+ * @param {string} arch
+ * @returns {Promise}
+ */
+
+
+ installLocalNodeModules(arch = this.$.env.options.ia32 || process.arch === 'ia32' ? 'ia32' : 'x64') {
+ const localDependencies = _lodash.default.values(this.packageJson.localDependencies);
+
+ if (localDependencies.length === 0) {
+ return Promise.resolve();
+ }
+
+ this.log.info('installing local node modules');
+ const lastRebuild = this.$.electronBuilder.prepareLastRebuildObject(arch);
+ const env = this.$.electronBuilder.getGypEnv(lastRebuild.frameworkInfo, lastRebuild.platform, lastRebuild.arch);
+ const installer = new _installLocal.LocalInstaller({
+ [this.$.env.paths.electronApp.root]: localDependencies
+ }, {
+ npmEnv: env
+ });
+ (0, _installLocal.progress)(installer);
+ return installer.install();
+ }
+ /**
+ * Rebuild binary dependencies against Electron's node headers.
+ * @returns {Promise}
+ */
+
+
+ rebuildDeps(install = false) {
+ if (install) {
+ this.log.info('issuing node_modules install from electron-builder');
+ } else {
+ this.log.info('issuing native modules rebuild from electron-builder');
+ }
+
+ const arch = this.$.env.options.ia32 || process.arch === 'ia32' ? 'ia32' : 'x64';
+
+ if (this.$.env.options.ia32) {
+ this.log.verbose('forcing rebuild for 32bit');
+ } else {
+ this.log.verbose(`rebuilding for ${arch}`);
+ }
+
+ return this.$.electronBuilder.installOrRebuild(arch, undefined, install);
+ }
+ /**
+ * Update package.json fields accordingly to what is set in settings.json.
+ *
+ * packageJson.name = settings.projectName
+ * packageJson.version = settings.version
+ * packageJson.* = settings.packageJsonFields
+ */
+
+
+ updatePackageJsonFields() {
+ this.log.verbose('updating package.json fields');
+ const settings = this.$.desktop.getSettings();
+ /** @type {desktopSettings} */
+
+ const packageJson = this.scaffold.getDefaultPackageJson();
+ packageJson.version = settings.version;
+
+ if ('packageJsonFields' in settings) {
+ (0, _assignIn.default)(packageJson, settings.packageJsonFields);
+ }
+
+ (0, _assignIn.default)(packageJson, {
+ name: settings.projectName
+ });
+ this.log.debug('writing updated package.json');
+
+ _fs.default.writeFileSync(this.$.env.paths.electronApp.packageJson, JSON.stringify(packageJson, null, 4));
+
+ this.packageJson = packageJson;
+ }
+ /**
+ * Updates settings.json with env (prod/dev) information and versions.
+ */
+
+
+ async updateSettingsJsonFields() {
+ this.log.debug('updating settings.json fields');
+ const settings = this.$.desktop.getSettings(); // Save versions.
+
+ settings.compatibilityVersion = this.compatibilityVersion; // Pass information about build type to the settings.json.
+
+ settings.env = this.$.env.isProductionBuild() ? 'prod' : 'dev';
+ const version = await this.$.desktop.getHashVersion();
+ settings.desktopVersion = `${version}_${settings.env}`;
+ settings.meteorDesktopVersion = this.$.getVersion();
+
+ if (this.$.env.options.prodDebug) {
+ settings.prodDebug = true;
+ }
+
+ _fs.default.writeFileSync(this.$.env.paths.desktopTmp.settings, JSON.stringify(settings, null, 4));
+ }
+ /**
+ * Copies files from prepared .desktop to desktop.asar in electron app.
+ */
+
+
+ packDesktopToAsar() {
+ this.log.info('packing .desktop to asar');
+ return new Promise((resolve, reject) => {
+ _asar.default.createPackage(this.$.env.paths.desktopTmp.root, this.$.env.paths.electronApp.desktopAsar).then(() => {
+ this.log.verbose('clearing temporary .desktop');
+ this.$.utils.rmWithRetries('-rf', this.$.env.paths.desktopTmp.root).then(() => {
+ resolve();
+ }).catch(e => {
+ reject(e);
+ });
+ resolve();
+ });
+ });
+ }
+ /**
+ * Makes a temporary copy of .desktop.
+ */
+
+
+ copyDesktopToDesktopTemp() {
+ this.log.verbose('copying .desktop to temporary location');
+
+ _shelljs.default.cp('-rf', this.$.env.paths.desktop.root, this.$.env.paths.desktopTmp.root); // Remove test files.
+
+
+ _del.default.sync([_path.default.join(this.$.env.paths.desktopTmp.root, '**', '*.test.js')], {
+ force: true
+ });
+ }
+ /**
+ * Runs babel and uglify over .desktop if requested.
+ */
+
+
+ async transpileAndMinify() {
+ this.log.info('transpiling and uglifying');
+ const settings = this.$.desktop.getSettings();
+ const options = 'uglifyOptions' in settings ? settings.uglifyOptions : {};
+ const uglifyingEnabled = 'uglify' in settings && !!settings.uglify;
+ const preset = (0, _presetEnv.default)({
+ assertVersion: () => {}
+ }, {
+ targets: {
+ node: '12'
+ }
+ });
+ const {
+ data: files
+ } = await this.$.utils.readDir(this.$.env.paths.desktopTmp.root);
+ files.forEach(file => {
+ if (file.endsWith('.js')) {
+ let {
+ code
+ } = (0, _core.transformFileSync)(file, {
+ presets: [preset]
+ });
+ let error;
+
+ if (settings.env === 'prod' && uglifyingEnabled) {
+ ({
+ code,
+ error
+ } = _terser.default.minify(code, options));
+ }
+
+ if (error) {
+ throw new Error(error);
+ }
+
+ _fs.default.writeFileSync(file, code);
+ }
+ });
+ }
+ /**
+ * Moves all the files that should not be packed into asar into a safe location which is the
+ * 'extracted' dir in the electron app.
+ */
+
+
+ async excludeFilesFromArchive() {
+ this.log.info('excluding files from packing'); // Ensure empty `extracted` dir
+
+ try {
+ await this.$.utils.rmWithRetries('-rf', this.$.env.paths.electronApp.extracted);
+ } catch (e) {
+ throw new Error(e);
+ }
+
+ _shelljs.default.mkdir(this.$.env.paths.electronApp.extracted);
+
+ const configs = this.$.desktop.gatherModuleConfigs(); // Move files that should not be asar'ed.
+
+ configs.forEach(config => {
+ const moduleConfig = config;
+
+ if ('extract' in moduleConfig) {
+ if (!Array.isArray(moduleConfig.extract)) {
+ moduleConfig.extract = [moduleConfig.extract];
+ }
+
+ moduleConfig.extract.forEach(file => {
+ this.log.debug(`excluding ${file} from ${config.name}`);
+
+ const filePath = _path.default.join(this.$.env.paths.desktopTmp.modules, moduleConfig.dirName, file);
+
+ const destinationPath = _path.default.join(this.$.env.paths.electronApp.extracted, moduleConfig.dirName);
+
+ if (!this.$.utils.exists(destinationPath)) {
+ _shelljs.default.mkdir(destinationPath);
+ }
+
+ _shelljs.default.mv(filePath, destinationPath);
+ });
+ }
+ });
+ }
+
+}
+
+exports.default = ElectronApp;
+//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["shell","config","fatal","ElectronApp","constructor","$","log","Log","scaffold","ElectronAppScaffold","depsManager","DependenciesManager","getDefaultPackageJson","dependencies","meteorApp","packageJson","version","compatibilityVersion","deprectatedPlugins","packSkeletonToAsar","excludeFromDel","info","Promise","resolve","extract","getModulesToExtract","debug","fs","renameSync","env","paths","electronApp","nodeModules","path","join","appRoot","extracted","extractModules","asar","createPackage","appAsar","then","mv","forEach","module","cp","extractedNodeModules","utils","exists","extractedNodeModulesBin","exclude","concat","del","sync","root","sep","map","pathToExclude","force","ext","length","rm","mkdirSync","extractBin","JSON","parse","readFileSync","e","bins","bin","Object","keys","extension","binFilePath","symlinkExists","binaryModulesDetector","BinaryModuleDetector","toBeExtracted","detect","desktop","getSettings","Array","isArray","merge","verbose","calculateCompatibilityVersion","settings","desktopHCPCompatibilityVersion","warn","md5","crypto","createHash","getDependencies","dependenciesSorted","sort","dependency","mainCompatibilityVersion","getVersion","split","push","desktopCompatibilityVersion","process","METEOR_DESKTOP_DEBUG_DESKTOP_COMPATIBILITY_VERSION","METEOR_DESKTOP_DEBUG","stringify","update","digest","init","electron","electronBuilder","exit","build","run","check","options","error","updateGitIgnore","rootName","removeDeprecatedPackages","ensureDesktopHCPPackages","make","fileName","dirName","existsSync","copyFileSync","exposeElectronModules","updatePackageJsonFields","updateDependenciesList","handleTemporaryNodeModules","nodeModulesRemoved","handleStateOfNodeModules","rebuildDeps","linkNpmPackages","installLocalNodeModules","ensureMeteorDependencies","isProductionBuild","copyDesktopToDesktopTemp","updateSettingsJsonFields","excludeFilesFromArchive","transpileAndMinify","packDesktopToAsar","getMeteorClientBuild","exposedModules","preload","modules","reduce","prev","replace","writeFileSync","packages","packagesWithVersion","plugins","plugin","meteorDependencies","unshift","packageName","packagesCount","filter","value","includes","substr","meteorManager","ensurePackages","Error","ia32","rmWithRetries","tmpNodeModules","promises","linkPackages","runNpm","undefined","all","ensureDeps","stdio","checkPluginsVersion","pluginsVersions","settingsJson","scaffoldPluginsVersion","pluginName","semver","lt","desktopDependencies","mergeDependencies","fromSettings","getRemoteDependencies","localDependencies","getLocalDependencies","arch","_","values","lastRebuild","prepareLastRebuildObject","getGypEnv","frameworkInfo","platform","installer","LocalInstaller","npmEnv","progress","install","installOrRebuild","assignIn","packageJsonFields","name","projectName","getHashVersion","desktopVersion","meteorDesktopVersion","prodDebug","desktopTmp","reject","desktopAsar","catch","uglifyOptions","uglifyingEnabled","uglify","preset","presetEnv","assertVersion","targets","node","data","files","readDir","file","endsWith","code","transformFileSync","presets","minify","mkdir","configs","gatherModuleConfigs","moduleConfig","filePath","destinationPath"],"sources":["../lib/electronApp.js"],"sourcesContent":["// eslint-disable-next-line no-unused-vars\nimport regeneratorRuntime from 'regenerator-runtime/runtime';\nimport asar from '@electron/asar';\nimport assignIn from 'lodash/assignIn';\nimport _ from 'lodash';\nimport { LocalInstaller, progress } from 'install-local';\nimport { transformFileSync } from '@babel/core';\nimport crypto from 'crypto';\nimport del from 'del';\nimport presetEnv from '@babel/preset-env';\nimport fs from 'fs';\nimport path from 'path';\nimport shell from 'shelljs';\nimport semver from 'semver';\nimport uglify from 'terser';\n\nimport Log from './log';\nimport ElectronAppScaffold from './electronAppScaffold';\nimport DependenciesManager from './dependenciesManager';\nimport BinaryModuleDetector from './binaryModulesDetector';\n\nshell.config.fatal = true;\n\n/**\n * Represents the .desktop dir scaffold.\n * @class\n */\nexport default class ElectronApp {\n    /**\n     * @param {MeteorDesktop} $ - context\n     * @constructor\n     */\n    constructor($) {\n        this.log = new Log('electronApp');\n        this.scaffold = new ElectronAppScaffold($);\n        this.depsManager = new DependenciesManager(\n            $,\n            this.scaffold.getDefaultPackageJson().dependencies\n        );\n        this.$ = $;\n        this.meteorApp = this.$.meteorApp;\n        this.packageJson = null;\n        this.version = null;\n        this.compatibilityVersion = null;\n        this.deprectatedPlugins = ['meteor-desktop-localstorage'];\n    }\n\n    /**\n     * Makes an app.asar from the skeleton app.\n     * @property {Array} excludeFromDel - list of paths to exclude from deleting\n     * @returns {Promise}\n     */\n    packSkeletonToAsar(excludeFromDel = []) {\n        this.log.info('packing skeleton app and node_modules to asar archive');\n        return new Promise((resolve) => {\n            const extract = this.getModulesToExtract();\n\n            // We want to pack skeleton app and node_modules together, so we need to temporarily\n            // move node_modules to app dir.\n            this.log.debug('moving node_modules to app dir');\n\n            fs.renameSync(\n                this.$.env.paths.electronApp.nodeModules,\n                path.join(this.$.env.paths.electronApp.appRoot, 'node_modules')\n            );\n\n            let extracted = false;\n            extracted = this.extractModules(extract);\n\n            this.log.debug('packing');\n            asar.createPackage(\n                this.$.env.paths.electronApp.appRoot,\n                this.$.env.paths.electronApp.appAsar\n            )\n                .then(() => {\n                    // Lets move the node_modules back.\n                    this.log.debug('moving node_modules back from app dir');\n\n                    shell.mv(\n                        path.join(this.$.env.paths.electronApp.appRoot, 'node_modules'),\n                        this.$.env.paths.electronApp.nodeModules\n                    );\n\n                    if (extracted) {\n                        // We need to create a full node modules back. In other words we want\n                        // the extracted modules back.\n                        extract.forEach(module => shell.cp(\n                            '-rf',\n                            path.join(this.$.env.paths.electronApp.extractedNodeModules, module),\n                            path.join(this.$.env.paths.electronApp.nodeModules, module)\n                        ));\n\n                        // Get the .bin back.\n                        if (this.$.utils.exists(\n                            this.$.env.paths.electronApp.extractedNodeModulesBin\n                        )) {\n                            shell.cp(\n                                path.join(this.$.env.paths.electronApp.extractedNodeModulesBin, '*'),\n                                path.join(this.$.env.paths.electronApp.nodeModules, '.bin')\n                            );\n                        }\n                    }\n\n                    this.log.debug('deleting source files');\n                    const exclude = [this.$.env.paths.electronApp.nodeModules].concat(\n                        [\n                            this.$.env.paths.electronApp.appAsar,\n                            this.$.env.paths.electronApp.packageJson\n                        ],\n                        excludeFromDel\n                    );\n\n                    del.sync(\n                        [`${this.$.env.paths.electronApp.root}${path.sep}*`].concat(\n                            exclude.map(pathToExclude => `!${pathToExclude}`)\n                        ),\n                        { force: true }\n                    );\n                    resolve();\n                });\n        });\n    }\n\n    /**\n     * Moves specified node modules to a separate directory.\n     * @param {Array} extract\n     * @returns {boolean}\n     */\n    extractModules(extract) {\n        const ext = ['.js', '.bat', '.sh', '.cmd', ''];\n\n        if (extract.length > 0) {\n            if (this.$.utils.exists(this.$.env.paths.electronApp.extractedNodeModules)) {\n                shell.rm('-rf', this.$.env.paths.electronApp.extractedNodeModules);\n            }\n            fs.mkdirSync(this.$.env.paths.electronApp.extractedNodeModules);\n            fs.mkdirSync(this.$.env.paths.electronApp.extractedNodeModulesBin);\n\n            extract.forEach((module) => {\n                fs.renameSync(\n                    path.join(this.$.env.paths.electronApp.appRoot, 'node_modules', module),\n                    path.join(this.$.env.paths.electronApp.extractedNodeModules, module),\n                );\n                // Move bins.\n                this.extractBin(module, ext);\n            });\n\n            return true;\n        }\n        return false;\n    }\n\n    /**\n     * Extracts the bin files associated with a certain node modules.\n     *\n     * @param module\n     * @param ext\n     */\n    extractBin(module, ext) {\n        let packageJson;\n        try {\n            packageJson = JSON.parse(\n                fs.readFileSync(\n                    path.join(\n                        this.$.env.paths.electronApp.extractedNodeModules, module, 'package.json'\n                    ),\n                    'utf8'\n                )\n            );\n        } catch (e) {\n            packageJson = {};\n        }\n\n\n        const bins = ('bin' in packageJson && typeof packageJson.bin === 'object') ? Object.keys(packageJson.bin) : [];\n\n        if (bins.length > 0) {\n            bins.forEach((bin) => {\n                ext.forEach((extension) => {\n                    const binFilePath = path.join(\n                        this.$.env.paths.electronApp.appRoot,\n                        'node_modules',\n                        '.bin',\n                        `${bin}${extension}`\n                    );\n                    if (this.$.utils.exists(binFilePath) ||\n                        this.$.utils.symlinkExists(binFilePath)\n                    ) {\n                        fs.renameSync(\n                            binFilePath,\n                            path.join(\n                                this.$.env.paths.electronApp.extractedNodeModulesBin,\n                                `${bin}${extension}`\n                            )\n                        );\n                    }\n                });\n            });\n        }\n    }\n\n    /**\n     * Merges the `extract` field with automatically detected modules.\n     */\n    getModulesToExtract() {\n        const binaryModulesDetector =\n            new BinaryModuleDetector(this.$.env.paths.electronApp.nodeModules);\n        const toBeExtracted = binaryModulesDetector.detect();\n\n        let { extract } = this.$.desktop.getSettings();\n\n        if (!Array.isArray(extract)) {\n            extract = [];\n        }\n\n        const merge = {};\n        toBeExtracted.concat(extract).forEach((module) => {\n            merge[module] = true;\n        });\n        extract = Object.keys(merge);\n        if (extract.length > 0) {\n            this.log.verbose(`resultant modules to extract list is: ${extract.join(', ')}`);\n        }\n        return extract;\n    }\n\n    /**\n     * Calculates a md5 from all dependencies.\n     */\n    calculateCompatibilityVersion() {\n        this.log.verbose('calculating compatibility version');\n        const settings = this.$.desktop.getSettings();\n\n        if (('desktopHCPCompatibilityVersion' in settings)) {\n            this.compatibilityVersion = `${settings.desktopHCPCompatibilityVersion}`;\n            this.log.warn(`compatibility version overridden to ${this.compatibilityVersion}`);\n            return;\n        }\n\n        const md5 = crypto.createHash('md5');\n        let dependencies = this.depsManager.getDependencies();\n        const dependenciesSorted = Object.keys(dependencies).sort();\n        dependencies = dependenciesSorted.map(dependency =>\n            `${dependency}:${dependencies[dependency]}`);\n        const mainCompatibilityVersion = this.$.getVersion().split('.');\n        this.log.debug('meteor-desktop compatibility version is ',\n            `${mainCompatibilityVersion[0]}`);\n        dependencies.push(\n            `meteor-desktop:${mainCompatibilityVersion[0]}`\n        );\n\n        const desktopCompatibilityVersion = settings.version.split('.')[0];\n        this.log.debug('.desktop compatibility version is ', desktopCompatibilityVersion);\n        dependencies.push(\n            `desktop-app:${desktopCompatibilityVersion}`\n        );\n\n        if (process.env.METEOR_DESKTOP_DEBUG_DESKTOP_COMPATIBILITY_VERSION ||\n            process.env.METEOR_DESKTOP_DEBUG\n        ) {\n            this.log.debug(`compatibility version calculated from ${JSON.stringify(dependencies)}`);\n        }\n\n        md5.update(JSON.stringify(dependencies));\n\n        this.compatibilityVersion = md5.digest('hex');\n    }\n\n    async init() {\n        try {\n            await this.$.electron.init();\n            await this.$.electronBuilder.init();\n        } catch (e) {\n            this.log.warn('error occurred while initialising electron and electron-builder integration', e);\n            process.exit(1);\n        }\n    }\n\n    /**\n     * Runs all necessary tasks to build the desktopified app.\n     */\n    async build(run = false) {\n        // TODO: refactor to a task runner\n        this.log.info('scaffolding');\n\n        if (!this.$.desktop.check()) {\n            if (!this.$.env.options.scaffold) {\n                this.log.error('seems that you do not have a .desktop dir in your project or it is' +\n                    ' corrupted. Run \\'npm run desktop -- init\\' to get a new one.');\n                // Do not fail, so that npm will not print his error stuff to console.\n                process.exit(0);\n            } else {\n                this.$.desktop.scaffold();\n                this.$.meteorApp.updateGitIgnore();\n            }\n        }\n\n        await this.init();\n\n\n        try {\n            this.$.meteorApp.updateGitIgnore();\n        } catch (e) {\n            this.log.warn(`error occurred while adding ${this.$.env.paths.electronApp.rootName}` +\n                'to .gitignore: ', e);\n        }\n\n        try {\n            await this.$.meteorApp.removeDeprecatedPackages();\n        } catch (e) {\n            this.log.error('error while removing deprecated packages: ', e);\n            process.exit(1);\n        }\n\n        try {\n            await this.$.meteorApp.ensureDesktopHCPPackages();\n        } catch (e) {\n            this.log.error('error while checking for required packages: ', e);\n            process.exit(1);\n        }\n\n        try {\n            await this.scaffold.make();\n        } catch (e) {\n            this.log.error('error while scaffolding: ', e);\n            process.exit(1);\n        }\n\n        try {\n            const fileName = '.npmrc';\n            const dirName = '.meteor/desktop-build';\n            if (fs.existsSync(dirName) && fs.existsSync(fileName)) {\n                fs.copyFileSync(fileName, `${dirName}/${fileName}`);\n            }\n        } catch (e) {\n            this.log.warn('error while copying .npmrc', e);\n        }\n\n        try {\n            await this.exposeElectronModules();\n        } catch (e) {\n            this.log.error('error while exposing electron modules: ', e);\n            process.exit(1);\n        }\n\n        try {\n            this.updatePackageJsonFields();\n        } catch (e) {\n            this.log.error('error while updating package.json: ', e);\n        }\n\n        try {\n            this.updateDependenciesList();\n        } catch (e) {\n            this.log.error('error while merging dependencies list: ', e);\n        }\n\n        try {\n            this.calculateCompatibilityVersion();\n        } catch (e) {\n            this.log.error('error while calculating compatibility version: ', e);\n            process.exit(1);\n        }\n\n        try {\n            await this.handleTemporaryNodeModules();\n        } catch (e) {\n            this.log.error('error occurred while handling temporary node_modules: ', e);\n            process.exit(1);\n        }\n\n        let nodeModulesRemoved;\n        try {\n            nodeModulesRemoved = await this.handleStateOfNodeModules();\n        } catch (e) {\n            this.log.error('error occurred while clearing node_modules: ', e);\n            process.exit(1);\n        }\n\n        try {\n            await this.rebuildDeps(true);\n        } catch (e) {\n            this.log.error('error occurred while installing node_modules: ', e);\n            process.exit(1);\n        }\n\n        if (!nodeModulesRemoved) {\n            try {\n                await this.rebuildDeps();\n            } catch (e) {\n                this.log.error('error occurred while rebuilding native node modules: ', e);\n                process.exit(1);\n            }\n        }\n\n        try {\n            await this.linkNpmPackages();\n        } catch (e) {\n            this.log.error(`linking packages failed: ${e}`);\n            process.exit(1);\n        }\n\n        try {\n            await this.installLocalNodeModules();\n        } catch (e) {\n            this.log.error('error occurred while installing local node modules: ', e);\n            process.exit(1);\n        }\n\n\n        try {\n            await this.ensureMeteorDependencies();\n        } catch (e) {\n            this.log.error('error occurred while ensuring meteor dependencies are installed: ', e);\n            process.exit(1);\n        }\n\n\n        if (this.$.env.isProductionBuild()) {\n            try {\n                await this.packSkeletonToAsar();\n            } catch (e) {\n                this.log.error('error while packing skeleton to asar: ', e);\n                process.exit(1);\n            }\n        }\n\n        // TODO: find a way to avoid copying .desktop to a temp location\n        try {\n            this.copyDesktopToDesktopTemp();\n        } catch (e) {\n            this.log.error('error while copying .desktop to a temporary location: ', e);\n            process.exit(1);\n        }\n\n        try {\n            await this.updateSettingsJsonFields();\n        } catch (e) {\n            this.log.error('error while updating settings.json: ', e);\n            process.exit(1);\n        }\n\n        try {\n            await this.excludeFilesFromArchive();\n        } catch (e) {\n            this.log.error('error while excluding files from packing to asar: ', e);\n            process.exit(1);\n        }\n\n        try {\n            await this.transpileAndMinify();\n        } catch (e) {\n            this.log.error('error while transpiling or minifying: ', e);\n        }\n\n        try {\n            await this.packDesktopToAsar();\n        } catch (e) {\n            this.log.error('error occurred while packing .desktop to asar: ', e);\n            process.exit(1);\n        }\n\n        try {\n            await this.getMeteorClientBuild();\n        } catch (e) {\n            this.log.error('error occurred during getting meteor mobile build: ', e);\n        }\n\n        if (run) {\n            this.log.info('running');\n            this.$.electron.run();\n        } else {\n            this.log.info('built');\n        }\n    }\n\n    /**\n     * Copies the `exposedModules` setting from `settings.json` into `preload.js` modifying its code\n     * so that the script will have it hardcoded.\n     */\n    exposeElectronModules() {\n        const { exposedModules } = this.$.desktop.getSettings();\n        if (exposedModules && Array.isArray(exposedModules) && exposedModules.length > 0) {\n            let preload = fs.readFileSync(this.$.env.paths.electronApp.preload, 'utf8');\n            const modules = this.$.desktop.getSettings()\n                .exposedModules\n                .reduce(\n                    // eslint-disable-next-line no-return-assign,no-param-reassign\n                    (prev, module) => (prev += `'${module}', `, prev), ''\n                );\n\n            preload = preload.replace('const exposedModules = [', `const exposedModules = [${modules}`);\n            fs.writeFileSync(this.$.env.paths.electronApp.preload, preload);\n        }\n    }\n\n    /**\n     * Ensures all required dependencies are added to the Meteor project.\n     * @returns {Promise.<void>}\n     */\n    async ensureMeteorDependencies() {\n        let packages = [];\n        const packagesWithVersion = [];\n        let plugins = 'plugins [';\n\n        Object.keys(this.$.desktop.getDependencies().plugins).forEach((plugin) => {\n            // Read package.json of the plugin.\n            const packageJson =\n                JSON.parse(\n                    fs.readFileSync(\n                        path.join(\n                            this.$.env.paths.electronApp.nodeModules, plugin, 'package.json'\n                        ),\n                        'utf8'\n                    )\n                );\n\n            if ('meteorDependencies' in packageJson && typeof packageJson.meteorDependencies === 'object') {\n                plugins += `${plugin}, `;\n                packages.unshift(...Object.keys(packageJson.meteorDependencies));\n                packagesWithVersion.unshift(...packages.map((packageName) => {\n                    if (packageJson.meteorDependencies[packageName] === '@version') {\n                        return `${packageName}@${packageJson.version}`;\n                    }\n                    return `${packageName}@${packageJson.meteorDependencies[packageName]}`;\n                }));\n            }\n        });\n\n        const packagesCount = packages.length;\n        packages = packages.filter(value => !this.deprectatedPlugins.includes(value));\n        if (packagesCount !== packages.length) {\n            this.log.warn('you have some deprecated meteor desktop plugins in your settings, please remove ' +\n                `them (deprecated plugins: ${this.deprectatedPlugins.join(', ')})`);\n        }\n\n        if (packages.length > 0) {\n            plugins = `${plugins.substr(0, plugins.length - 2)}]`;\n            try {\n                await this.$.meteorApp.meteorManager.ensurePackages(\n                    packages, packagesWithVersion, plugins\n                );\n            } catch (e) {\n                throw new Error(e);\n            }\n        }\n    }\n\n    /**\n     * Builds meteor app.\n     */\n    async getMeteorClientBuild() {\n        await this.$.meteorApp.build();\n    }\n\n    /**\n     * Removes node_modules if needed.\n     * @returns {Promise<void>}\n     */\n    async handleStateOfNodeModules() {\n        if (this.$.env.isProductionBuild() || this.$.env.options.ia32) {\n            if (!this.$.env.isProductionBuild()) {\n                this.log.info('clearing node_modules because we need to have it clear for ia32 rebuild');\n            } else {\n                this.log.info('clearing node_modules because this is a production build');\n            }\n            try {\n                await this.$.utils.rmWithRetries(\n                    '-rf', this.$.env.paths.electronApp.nodeModules\n                );\n            } catch (e) {\n                throw new Error(e);\n            }\n            return true;\n        }\n        return false;\n    }\n\n    /**\n     * If there is a temporary node_modules folder and no node_modules folder, we will\n     * restore it, as it might be a leftover from an interrupted flow.\n     * @returns {Promise<void>}\n     */\n    async handleTemporaryNodeModules() {\n        if (this.$.utils.exists(this.$.env.paths.electronApp.tmpNodeModules)) {\n            if (!this.$.utils.exists(this.$.env.paths.electronApp.nodeModules)) {\n                this.log.debug('moving temp node_modules back');\n                shell.mv(\n                    this.$.env.paths.electronApp.tmpNodeModules,\n                    this.$.env.paths.electronApp.nodeModules\n                );\n            } else {\n                // If there is a node_modules folder, we should clear the temporary one.\n                this.log.debug('clearing temp node_modules because new one is already created');\n                try {\n                    await this.$.utils.rmWithRetries(\n                        '-rf', this.$.env.paths.electronApp.tmpNodeModules\n                    );\n                } catch (e) {\n                    throw new Error(e);\n                }\n            }\n        }\n    }\n\n    /**\n     * Runs npm link for every package specified in settings.json->linkPackages.\n     */\n    async linkNpmPackages() {\n        if (this.$.env.isProductionBuild()) {\n            return;\n        }\n        const settings = this.$.desktop.getSettings();\n        const promises = [];\n        if ('linkPackages' in this.$.desktop.getSettings()) {\n            if (Array.isArray(settings.linkPackages)) {\n                settings.linkPackages.forEach(packageName =>\n                    promises.push(\n                        this.$.meteorApp.runNpm(\n                            ['link', packageName],\n                            undefined,\n                            this.$.env.paths.electronApp.root\n                        )\n                    ));\n            }\n        }\n        await Promise.all(promises);\n    }\n\n    /**\n     * Runs npm in the electron app to get the dependencies installed.\n     * @returns {Promise}\n     */\n    async ensureDeps() {\n        this.log.info('installing dependencies');\n        if (this.$.utils.exists(this.$.env.paths.electronApp.nodeModules)) {\n            this.log.debug('running npm prune to wipe unneeded dependencies');\n            try {\n                await this.runNpm(['prune']);\n            } catch (e) {\n                throw new Error(e);\n            }\n        }\n        try {\n            await this.runNpm(['install'], this.$.env.stdio);\n        } catch (e) {\n            throw new Error(e);\n        }\n    }\n\n    /**\n     * Warns if plugins version are outdated in compare to the newest scaffold.\n     * @param {Object} pluginsVersions - current plugins versions from settings.json\n     */\n    checkPluginsVersion(pluginsVersions) {\n        const settingsJson = JSON.parse(\n            fs.readFileSync(path.join(this.$.env.paths.scaffold, 'settings.json'))\n        );\n        const scaffoldPluginsVersion = this.$.desktop.getDependencies(settingsJson, false).plugins;\n        Object.keys(pluginsVersions).forEach((pluginName) => {\n            if (pluginName in scaffoldPluginsVersion &&\n                scaffoldPluginsVersion[pluginName] !== pluginsVersions[pluginName] &&\n                semver.lt(pluginsVersions[pluginName], scaffoldPluginsVersion[pluginName])\n            ) {\n                this.log.warn(`you are using outdated version ${pluginsVersions[pluginName]} of ` +\n                    `${pluginName}, the suggested version to use is ` +\n                    `${scaffoldPluginsVersion[pluginName]}`);\n            }\n        });\n    }\n\n    /**\n     * Merges core dependency list with the dependencies from .desktop.\n     */\n    updateDependenciesList() {\n        this.log.info('updating list of package.json\\'s dependencies');\n        const desktopDependencies = this.$.desktop.getDependencies();\n\n        this.checkPluginsVersion(desktopDependencies.plugins);\n\n        this.log.debug('merging settings.json[dependencies]');\n        this.depsManager.mergeDependencies(\n            'settings.json[dependencies]',\n            desktopDependencies.fromSettings\n        );\n        this.log.debug('merging settings.json[plugins]');\n        this.depsManager.mergeDependencies(\n            'settings.json[plugins]',\n            desktopDependencies.plugins\n        );\n\n        this.log.debug('merging dependencies from modules');\n        Object.keys(desktopDependencies.modules).forEach(module =>\n            this.depsManager.mergeDependencies(\n                `module[${module}]`,\n                desktopDependencies.modules[module]\n            ));\n\n        this.packageJson.dependencies = this.depsManager.getRemoteDependencies();\n        this.packageJson.localDependencies = this.depsManager.getLocalDependencies();\n\n        this.log.debug('writing updated package.json');\n        fs.writeFileSync(\n            this.$.env.paths.electronApp.packageJson, JSON.stringify(this.packageJson, null, 2)\n        );\n    }\n\n    /**\n     * Install node modules from local paths using local-install.\n     *\n     * @param {string} arch\n     * @returns {Promise}\n     */\n    installLocalNodeModules(arch = this.$.env.options.ia32 || process.arch === 'ia32' ? 'ia32' : 'x64') {\n        const localDependencies = _.values(this.packageJson.localDependencies);\n        if (localDependencies.length === 0) {\n            return Promise.resolve();\n        }\n        this.log.info('installing local node modules');\n        const lastRebuild = this.$.electronBuilder.prepareLastRebuildObject(arch);\n        const env = this.$.electronBuilder.getGypEnv(lastRebuild.frameworkInfo, lastRebuild.platform, lastRebuild.arch);\n        const installer = new LocalInstaller(\n            { [this.$.env.paths.electronApp.root]: localDependencies },\n            { npmEnv: env }\n        );\n        progress(installer);\n        return installer.install();\n    }\n\n    /**\n     * Rebuild binary dependencies against Electron's node headers.\n     * @returns {Promise}\n     */\n    rebuildDeps(install = false) {\n        if (install) {\n            this.log.info('issuing node_modules install from electron-builder');\n        } else {\n            this.log.info('issuing native modules rebuild from electron-builder');\n        }\n\n        const arch = this.$.env.options.ia32 || process.arch === 'ia32' ? 'ia32' : 'x64';\n\n        if (this.$.env.options.ia32) {\n            this.log.verbose('forcing rebuild for 32bit');\n        } else {\n            this.log.verbose(`rebuilding for ${arch}`);\n        }\n\n        return this.$.electronBuilder.installOrRebuild(arch, undefined, install);\n    }\n\n    /**\n     * Update package.json fields accordingly to what is set in settings.json.\n     *\n     * packageJson.name = settings.projectName\n     * packageJson.version = settings.version\n     * packageJson.* = settings.packageJsonFields\n     */\n    updatePackageJsonFields() {\n        this.log.verbose('updating package.json fields');\n        const settings = this.$.desktop.getSettings();\n        /** @type {desktopSettings} */\n        const packageJson = this.scaffold.getDefaultPackageJson();\n\n        packageJson.version = settings.version;\n        if ('packageJsonFields' in settings) {\n            assignIn(packageJson, settings.packageJsonFields);\n        }\n        assignIn(packageJson, { name: settings.projectName });\n\n        this.log.debug('writing updated package.json');\n        fs.writeFileSync(\n            this.$.env.paths.electronApp.packageJson, JSON.stringify(packageJson, null, 4)\n        );\n        this.packageJson = packageJson;\n    }\n\n    /**\n     * Updates settings.json with env (prod/dev) information and versions.\n     */\n    async updateSettingsJsonFields() {\n        this.log.debug('updating settings.json fields');\n        const settings = this.$.desktop.getSettings();\n\n        // Save versions.\n        settings.compatibilityVersion = this.compatibilityVersion;\n\n        // Pass information about build type to the settings.json.\n        settings.env = (this.$.env.isProductionBuild()) ?\n            'prod' : 'dev';\n\n        const version = await this.$.desktop.getHashVersion();\n        settings.desktopVersion = `${version}_${settings.env}`;\n\n        settings.meteorDesktopVersion = this.$.getVersion();\n\n        if (this.$.env.options.prodDebug) {\n            settings.prodDebug = true;\n        }\n\n        fs.writeFileSync(\n            this.$.env.paths.desktopTmp.settings, JSON.stringify(settings, null, 4)\n        );\n    }\n\n    /**\n     * Copies files from prepared .desktop to desktop.asar in electron app.\n     */\n    packDesktopToAsar() {\n        this.log.info('packing .desktop to asar');\n        return new Promise((resolve, reject) => {\n            asar.createPackage(\n                this.$.env.paths.desktopTmp.root,\n                this.$.env.paths.electronApp.desktopAsar\n            )\n                .then(() => {\n                    this.log.verbose('clearing temporary .desktop');\n                    this.$.utils\n                        .rmWithRetries('-rf', this.$.env.paths.desktopTmp.root)\n                        .then(() => {\n                            resolve();\n                        })\n                        .catch((e) => {\n                            reject(e);\n                        });\n                    resolve();\n                });\n        });\n    }\n\n    /**\n     * Makes a temporary copy of .desktop.\n     */\n    copyDesktopToDesktopTemp() {\n        this.log.verbose('copying .desktop to temporary location');\n        shell.cp('-rf', this.$.env.paths.desktop.root, this.$.env.paths.desktopTmp.root);\n        // Remove test files.\n        del.sync([\n            path.join(this.$.env.paths.desktopTmp.root, '**', '*.test.js')\n        ], { force: true });\n    }\n\n\n    /**\n     * Runs babel and uglify over .desktop if requested.\n     */\n    async transpileAndMinify() {\n        this.log.info('transpiling and uglifying');\n\n        const settings = this.$.desktop.getSettings();\n        const options = 'uglifyOptions' in settings ? settings.uglifyOptions : {};\n\n        const uglifyingEnabled = 'uglify' in settings && !!settings.uglify;\n\n        const preset = presetEnv({ assertVersion: () => { } }, { targets: { node: '12' } });\n\n        const { data: files } = await this.$.utils.readDir(this.$.env.paths.desktopTmp.root);\n\n        files.forEach((file) => {\n            if (file.endsWith('.js')) {\n                let { code } = transformFileSync(file, {\n                    presets: [preset]\n                });\n                let error;\n                if (settings.env === 'prod' && uglifyingEnabled) {\n                    ({ code, error } = uglify.minify(code, options));\n                }\n                if (error) {\n                    throw new Error(error);\n                }\n                fs.writeFileSync(file, code);\n            }\n        });\n    }\n\n    /**\n     * Moves all the files that should not be packed into asar into a safe location which is the\n     * 'extracted' dir in the electron app.\n     */\n    async excludeFilesFromArchive() {\n        this.log.info('excluding files from packing');\n\n        // Ensure empty `extracted` dir\n\n        try {\n            await this.$.utils.rmWithRetries('-rf', this.$.env.paths.electronApp.extracted);\n        } catch (e) {\n            throw new Error(e);\n        }\n\n        shell.mkdir(this.$.env.paths.electronApp.extracted);\n\n        const configs = this.$.desktop.gatherModuleConfigs();\n\n        // Move files that should not be asar'ed.\n        configs.forEach((config) => {\n            const moduleConfig = config;\n            if ('extract' in moduleConfig) {\n                if (!Array.isArray(moduleConfig.extract)) {\n                    moduleConfig.extract = [moduleConfig.extract];\n                }\n                moduleConfig.extract.forEach((file) => {\n                    this.log.debug(`excluding ${file} from ${config.name}`);\n                    const filePath = path.join(\n                        this.$.env.paths.desktopTmp.modules, moduleConfig.dirName, file\n                    );\n                    const destinationPath = path.join(\n                        this.$.env.paths.electronApp.extracted, moduleConfig.dirName\n                    );\n\n                    if (!this.$.utils.exists(destinationPath)) {\n                        shell.mkdir(destinationPath);\n                    }\n                    shell.mv(filePath, destinationPath);\n                });\n            }\n        });\n    }\n}\n"],"mappings":"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"}
\ No newline at end of file
diff --git a/dist/electronAppScaffold.js b/dist/electronAppScaffold.js
new file mode 100644
index 00000000..d108be14
--- /dev/null
+++ b/dist/electronAppScaffold.js
@@ -0,0 +1,142 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = void 0;
+
+var _runtime = _interopRequireDefault(require("regenerator-runtime/runtime"));
+
+var _fs = _interopRequireDefault(require("fs"));
+
+var _del = _interopRequireDefault(require("del"));
+
+var _shelljs = _interopRequireDefault(require("shelljs"));
+
+var _path = _interopRequireDefault(require("path"));
+
+var _log = _interopRequireDefault(require("./log"));
+
+var _skeletonDependencies = _interopRequireDefault(require("./skeletonDependencies"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+// eslint-disable-next-line no-unused-vars
+const {
+ join
+} = _path.default;
+_shelljs.default.config.fatal = true;
+/**
+ * Represents the .desktop dir scaffold.
+ */
+
+class ElectronAppScaffold {
+ /**
+ * @param {MeteorDesktop} $ - context
+ * @constructor
+ */
+ constructor($) {
+ this.log = new _log.default('electronAppScaffold');
+ this.$ = $;
+ this.packageJson = {
+ name: 'MyMeteorApp',
+ main: this.$.env.isProductionBuild() ? 'app.asar/index.js' : 'app/index.js',
+ dependencies: Object.assign({}, _skeletonDependencies.default)
+ };
+
+ if (!this.$.env.isProductionBuild() || this.$.env.options.prodDebug) {
+ this.packageJson.dependencies.devtron = '1.4.0';
+ this.packageJson.dependencies['electron-debug'] = '1.5.0';
+ }
+ }
+ /**
+ * Just a public getter from the default package.json object.
+ * @returns {Object}
+ */
+
+
+ getDefaultPackageJson() {
+ return Object.assign({}, this.packageJson);
+ }
+ /**
+ * Clear the electron app. Removes everything except the node_modules which would be a waste
+ * to delete. Later `npm prune` will keep it clear.
+ */
+
+
+ clear() {
+ if (!this.$.utils.exists(this.$.env.paths.electronApp.root)) {
+ this.log.verbose(`creating ${this.$.env.paths.electronApp.rootName}`);
+
+ _shelljs.default.mkdir(this.$.env.paths.electronApp.root);
+ }
+
+ return (0, _del.default)([`${this.$.env.paths.electronApp.root}${_path.default.sep}*`, `!${this.$.env.paths.electronApp.nodeModules}`], {
+ force: true
+ });
+ }
+ /**
+ * Just copies the Skeleton App into the electron app.
+ */
+
+
+ copySkeletonApp() {
+ this.log.verbose('copying skeleton app');
+
+ try {
+ _shelljs.default.cp('-rf', join(this.$.env.paths.meteorDesktop.skeleton, '*'), this.$.env.paths.electronApp.appRoot + _path.default.sep);
+ } catch (e) {
+ this.log.error('error while copying skeleton app:', e);
+ process.exit(1);
+ }
+ }
+ /**
+ * After clearing the electron app path, copies a fresh skeleton.
+ */
+
+
+ async make() {
+ try {
+ this.log.verbose(`clearing ${this.$.env.paths.electronApp.rootName}`);
+ await this.clear();
+ } catch (e) {
+ this.log.error(`error while removing ${this.$.env.paths.electronApp.root}: `, e);
+ process.exit(1);
+ }
+
+ this.createAppRoot();
+ this.copySkeletonApp(); // TODO: hey, wait, .gitignore is not needed - right?
+
+ /*
+ this.log.debug('creating .gitignore');
+ fs.writeFileSync(this.$.env.paths.electronApp.gitIgnore, [
+ 'node_modules'
+ ].join('\n'));
+ */
+
+ this.log.verbose('writing package.json');
+
+ _fs.default.writeFileSync(this.$.env.paths.electronApp.packageJson, JSON.stringify(this.packageJson, null, 2));
+ }
+ /**
+ * Creates the app directory in the electron app.
+ */
+
+
+ createAppRoot() {
+ try {
+ this.log.verbose(`creating ${this.$.env.paths.electronApp.appRoot}`);
+
+ _fs.default.mkdirSync(this.$.env.paths.electronApp.appRoot);
+ } catch (e) {
+ if (e.code !== 'EEXIST') {
+ this.log.error(`error while creating dir: ${this.$.env.paths.electronApp.appRoot}: `, e);
+ process.exit(1);
+ }
+ }
+ }
+
+}
+
+exports.default = ElectronAppScaffold;
+//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["join","path","shell","config","fatal","ElectronAppScaffold","constructor","$","log","Log","packageJson","name","main","env","isProductionBuild","dependencies","Object","assign","options","prodDebug","devtron","getDefaultPackageJson","clear","utils","exists","paths","electronApp","root","verbose","rootName","mkdir","del","sep","nodeModules","force","copySkeletonApp","cp","meteorDesktop","skeleton","appRoot","e","error","process","exit","make","createAppRoot","fs","writeFileSync","JSON","stringify","mkdirSync","code"],"sources":["../lib/electronAppScaffold.js"],"sourcesContent":["// eslint-disable-next-line no-unused-vars\nimport regeneratorRuntime from 'regenerator-runtime/runtime';\nimport fs from 'fs';\nimport del from 'del';\nimport shell from 'shelljs';\nimport path from 'path';\n\nimport Log from './log';\nimport dependencies from './skeletonDependencies';\n\nconst { join } = path;\nshell.config.fatal = true;\n\n/**\n * Represents the .desktop dir scaffold.\n */\nexport default class ElectronAppScaffold {\n    /**\n     * @param {MeteorDesktop} $ - context\n     * @constructor\n     */\n    constructor($) {\n        this.log = new Log('electronAppScaffold');\n        this.$ = $;\n\n        this.packageJson = {\n            name: 'MyMeteorApp',\n            main: (this.$.env.isProductionBuild()) ?\n                'app.asar/index.js' : 'app/index.js',\n            dependencies: Object.assign({}, dependencies)\n        };\n\n        if (!this.$.env.isProductionBuild() || this.$.env.options.prodDebug) {\n            this.packageJson.dependencies.devtron = '1.4.0';\n            this.packageJson.dependencies['electron-debug'] = '1.5.0';\n        }\n    }\n\n    /**\n     * Just a public getter from the default package.json object.\n     * @returns {Object}\n     */\n    getDefaultPackageJson() {\n        return Object.assign({}, this.packageJson);\n    }\n\n    /**\n     * Clear the electron app. Removes everything except the node_modules which would be a waste\n     * to delete. Later `npm prune` will keep it clear.\n     */\n    clear() {\n        if (!this.$.utils.exists(this.$.env.paths.electronApp.root)) {\n            this.log.verbose(`creating ${this.$.env.paths.electronApp.rootName}`);\n            shell.mkdir(this.$.env.paths.electronApp.root);\n        }\n\n        return del([\n            `${this.$.env.paths.electronApp.root}${path.sep}*`,\n            `!${this.$.env.paths.electronApp.nodeModules}`\n        ], { force: true });\n    }\n\n    /**\n     * Just copies the Skeleton App into the electron app.\n     */\n    copySkeletonApp() {\n        this.log.verbose('copying skeleton app');\n        try {\n            shell.cp(\n                '-rf',\n                join(this.$.env.paths.meteorDesktop.skeleton, '*'),\n                this.$.env.paths.electronApp.appRoot + path.sep\n            );\n        } catch (e) {\n            this.log.error('error while copying skeleton app:', e);\n            process.exit(1);\n        }\n    }\n\n    /**\n     * After clearing the electron app path, copies a fresh skeleton.\n     */\n    async make() {\n        try {\n            this.log.verbose(`clearing ${this.$.env.paths.electronApp.rootName}`);\n            await this.clear();\n        } catch (e) {\n            this.log.error(\n                `error while removing ${this.$.env.paths.electronApp.root}: `, e\n            );\n            process.exit(1);\n        }\n\n        this.createAppRoot();\n\n        this.copySkeletonApp();\n\n        // TODO: hey, wait, .gitignore is not needed - right?\n        /*\n        this.log.debug('creating .gitignore');\n        fs.writeFileSync(this.$.env.paths.electronApp.gitIgnore, [\n            'node_modules'\n        ].join('\\n'));\n        */\n        this.log.verbose('writing package.json');\n        fs.writeFileSync(\n            this.$.env.paths.electronApp.packageJson, JSON.stringify(this.packageJson, null, 2)\n        );\n    }\n\n    /**\n     * Creates the app directory in the electron app.\n     */\n    createAppRoot() {\n        try {\n            this.log.verbose(`creating ${this.$.env.paths.electronApp.appRoot}`);\n            fs.mkdirSync(this.$.env.paths.electronApp.appRoot);\n        } catch (e) {\n            if (e.code !== 'EEXIST') {\n                this.log.error(\n                    `error while creating dir: ${this.$.env.paths.electronApp.appRoot}: `, e\n                );\n                process.exit(1);\n            }\n        }\n    }\n}\n"],"mappings":"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"}
\ No newline at end of file
diff --git a/dist/electronBuilder.js b/dist/electronBuilder.js
new file mode 100644
index 00000000..d4438f23
--- /dev/null
+++ b/dist/electronBuilder.js
@@ -0,0 +1,384 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = void 0;
+
+var _runtime = _interopRequireDefault(require("regenerator-runtime/runtime"));
+
+var _shelljs = _interopRequireDefault(require("shelljs"));
+
+var _path = _interopRequireDefault(require("path"));
+
+var _fs = _interopRequireDefault(require("fs"));
+
+var _rimraf = _interopRequireDefault(require("rimraf"));
+
+var _crossSpawn = _interopRequireDefault(require("cross-spawn"));
+
+var _log = _interopRequireDefault(require("./log"));
+
+var _defaultDependencies = _interopRequireDefault(require("./defaultDependencies"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+// eslint-disable-next-line no-unused-vars
+
+/**
+ * Promisfied rimraf.
+ *
+ * @param {string} dirPath - path to the dir to be deleted
+ * @param {number} delay - delay the task by ms
+ * @returns {Promise}
+ */
+function removeDir(dirPath, delay = 0) {
+ return new Promise((resolve, reject) => {
+ setTimeout(() => {
+ (0, _rimraf.default)(dirPath, {
+ maxBusyTries: 100
+ }, err => {
+ if (err) {
+ reject(err);
+ } else {
+ resolve();
+ }
+ });
+ }, delay);
+ });
+}
+/**
+ * Wrapper for electron-builder.
+ */
+
+
+class InstallerBuilder {
+ /**
+ * @param {MeteorDesktop} $ - context
+ *
+ * @constructor
+ */
+ constructor($) {
+ this.log = new _log.default('electronBuilder');
+ this.$ = $;
+ this.firstPass = true;
+ this.lastRebuild = {};
+ this.currentContext = null;
+ this.installerDir = _path.default.join(this.$.env.options.output, this.$.env.paths.installerDir);
+ this.platforms = [];
+ }
+
+ async init() {
+ this.builder = await this.$.getDependency('electron-builder', _defaultDependencies.default['electron-builder']);
+ const appBuilder = await this.$.getDependency('app-builder-lib', _defaultDependencies.default['electron-builder'], false);
+ this.yarn = require(_path.default.join(appBuilder.path, 'out', 'util', 'yarn'));
+ this.getGypEnv = this.yarn.getGypEnv;
+ this.packageDependencies = require(_path.default.join(appBuilder.path, 'out', 'util', 'packageDependencies'));
+ }
+ /**
+ * Prepares the last rebuild object for electron-builder.
+ *
+ * @param {string} arch
+ * @param {string} platform
+ * @returns {Object}
+ */
+
+
+ prepareLastRebuildObject(arch, platform = process.platform) {
+ const productionDeps = this.packageDependencies.createLazyProductionDeps(this.$.env.paths.electronApp.root);
+ this.lastRebuild = {
+ frameworkInfo: {
+ version: this.$.getElectronVersion(),
+ useCustomDist: true
+ },
+ platform,
+ arch,
+ productionDeps
+ };
+ return this.lastRebuild;
+ }
+ /**
+ * Calls npm rebuild from electron-builder.
+ * @param {string} arch
+ * @param {string} platform
+ * @param {boolean} install
+ * @returns {Promise}
+ */
+
+
+ async installOrRebuild(arch, platform = process.platform, install = false) {
+ this.log.debug(`calling installOrRebuild from electron-builder for arch ${arch}`);
+ this.prepareLastRebuildObject(arch, platform);
+ await this.yarn.installOrRebuild(this.$.desktop.getSettings().builderOptions || {}, this.$.env.paths.electronApp.root, this.lastRebuild, install);
+ }
+ /**
+ * Callback invoked before build is made. Ensures that app.asar have the right rebuilt
+ * node_modules.
+ *
+ * @param {Object} context
+ * @returns {Promise}
+ */
+
+
+ beforeBuild(context) {
+ this.currentContext = Object.assign({}, context);
+ return new Promise((resolve, reject) => {
+ const platformMatches = process.platform === context.platform.nodeName;
+ const rebuild = platformMatches && context.arch !== this.lastRebuild.arch;
+
+ if (!platformMatches) {
+ this.log.warn('skipping dependencies rebuild because platform is different, if you have native ' + 'node modules as your app dependencies you should od the build on the target platform only');
+ }
+
+ if (!rebuild) {
+ this.moveNodeModulesOut().catch(e => reject(e)).then(() => setTimeout(() => resolve(false), 2000)); // Timeout helps on Windows to clear the file locks.
+ } else {
+ // Lets rebuild the node_modules for different arch.
+ this.installOrRebuild(context.arch, context.platform.nodeName).catch(e => reject(e)).then(() => this.$.electronApp.installLocalNodeModules(context.arch)).catch(e => reject(e)).then(() => {
+ this.$.electronApp.scaffold.createAppRoot();
+ this.$.electronApp.scaffold.copySkeletonApp();
+ return this.$.electronApp.packSkeletonToAsar([this.$.env.paths.electronApp.meteorAsar, this.$.env.paths.electronApp.desktopAsar, this.$.env.paths.electronApp.extracted]);
+ }).catch(e => reject(e)).then(() => this.moveNodeModulesOut()).catch(e => reject(e)).then(() => resolve(false));
+ }
+ });
+ }
+ /**
+ * Callback to be invoked after packing. Restores node_modules to the .desktop-build.
+ * @returns {Promise}
+ */
+
+
+ afterPack(context) {
+ this.platforms = this.platforms.filter(platform => platform !== context.electronPlatformName);
+
+ if (this.platforms.length !== 0) {
+ return Promise.resolve();
+ }
+
+ return new Promise((resolve, reject) => {
+ _shelljs.default.config.fatal = true;
+
+ if (this.$.utils.exists(this.$.env.paths.electronApp.extractedNodeModules)) {
+ this.log.debug('injecting extracted modules');
+
+ _shelljs.default.cp('-Rf', this.$.env.paths.electronApp.extractedNodeModules, _path.default.join(this.getPackagedAppPath(context), 'node_modules'));
+ }
+
+ this.log.debug('moving node_modules back'); // Move node_modules back.
+
+ try {
+ _shelljs.default.mv(this.$.env.paths.electronApp.tmpNodeModules, this.$.env.paths.electronApp.nodeModules);
+ } catch (e) {
+ reject(e);
+ return;
+ } finally {
+ _shelljs.default.config.reset();
+ }
+
+ if (this.firstPass) {
+ this.firstPass = false;
+ }
+
+ this.log.debug('node_modules moved back');
+ this.wait().catch(e => reject(e)).then(() => resolve());
+ });
+ }
+ /**
+ * This command kills orphaned MSBuild.exe processes.
+ * Sometime after native node_modules compilation they are still writing some logs,
+ * prevent node_modules from being deleted.
+ */
+
+
+ killMSBuild() {
+ if (this.currentContext.platform.nodeName !== 'win32') {
+ return;
+ }
+
+ try {
+ const out = _crossSpawn.default.sync('wmic', ['process', 'where', 'caption="MSBuild.exe"', 'get', 'processid']).stdout.toString('utf-8').split('\n');
+
+ const regex = new RegExp(/(\d+)/, 'gm'); // No we will check for those with the matching params.
+
+ out.forEach(line => {
+ const match = regex.exec(line) || false;
+
+ if (match) {
+ this.log.debug(`killing MSBuild.exe at pid: ${match[1]}`);
+
+ _crossSpawn.default.sync('taskkill', ['/pid', match[1], '/f', '/t']);
+ }
+
+ regex.lastIndex = 0;
+ });
+ } catch (e) {
+ this.log.debug('kill MSBuild failed');
+ }
+ }
+ /**
+ * Returns the path to packaged app.
+ * @returns {string}
+ */
+
+
+ getPackagedAppPath(context = {}) {
+ if (this.currentContext.platform.nodeName === 'darwin') {
+ return _path.default.join(this.installerDir, 'mac', `${context.packager.appInfo.productFilename}.app`, 'Contents', 'Resources', 'app');
+ }
+
+ const platformDir = `${this.currentContext.platform.nodeName === 'win32' ? 'win' : 'linux'}-${this.currentContext.arch === 'ia32' ? 'ia32-' : ''}unpacked`;
+ return _path.default.join(this.installerDir, platformDir, 'resources', 'app');
+ }
+ /**
+ * On Windows it waits for the app.asar in the packed app to be free (no file locks).
+ * @returns {*}
+ */
+
+
+ wait() {
+ if (this.currentContext.platform.nodeName !== 'win32') {
+ return Promise.resolve();
+ }
+
+ const appAsarPath = _path.default.join(this.getPackagedAppPath(), 'app.asar');
+
+ let retries = 0;
+ const self = this;
+ return new Promise((resolve, reject) => {
+ function check() {
+ _fs.default.open(appAsarPath, 'r+', (err, fd) => {
+ retries += 1;
+
+ if (err) {
+ if (err.code !== 'ENOENT') {
+ self.log.debug(`waiting for app.asar to be readable, ${'code' in err ? `currently reading it returns ${err.code}` : ''}`);
+
+ if (retries < 6) {
+ setTimeout(() => check(), 4000);
+ } else {
+ reject(`file is locked: ${appAsarPath}`);
+ }
+ } else {
+ resolve();
+ }
+ } else {
+ _fs.default.closeSync(fd);
+
+ resolve();
+ }
+ });
+ }
+
+ check();
+ });
+ }
+ /**
+ * Prepares the target object passed to the electron-builder.
+ *
+ * @returns {Map>>}
+ */
+
+
+ prepareTargets() {
+ let arch = this.$.env.options.ia32 ? 'ia32' : 'x64';
+ arch = this.$.env.options.allArchs ? 'all' : arch;
+ const targets = [];
+
+ if (this.$.env.options.win) {
+ targets.push(this.builder.dependency.Platform.WINDOWS);
+ }
+
+ if (this.$.env.options.linux) {
+ targets.push(this.builder.dependency.Platform.LINUX);
+ }
+
+ if (this.$.env.options.mac) {
+ targets.push(this.builder.dependency.Platform.MAC);
+ }
+
+ if (targets.length === 0) {
+ if (this.$.env.os.isWindows) {
+ targets.push(this.builder.dependency.Platform.WINDOWS);
+ } else if (this.$.env.os.isLinux) {
+ targets.push(this.builder.dependency.Platform.LINUX);
+ } else {
+ targets.push(this.builder.dependency.Platform.MAC);
+ }
+ }
+
+ return this.builder.dependency.createTargets(targets, null, arch);
+ }
+
+ async build() {
+ const settings = this.$.desktop.getSettings();
+
+ if (!('builderOptions' in settings)) {
+ this.log.error('no builderOptions in settings.json, aborting');
+ process.exit(1);
+ }
+
+ const builderOptions = Object.assign({}, settings.builderOptions);
+ builderOptions.asar = false;
+ builderOptions.npmRebuild = true;
+ builderOptions.beforeBuild = this.beforeBuild.bind(this);
+ builderOptions.afterPack = this.afterPack.bind(this);
+ builderOptions.electronVersion = this.$.getElectronVersion();
+ builderOptions.directories = {
+ app: this.$.env.paths.electronApp.root,
+ output: _path.default.join(this.$.env.options.output, this.$.env.paths.installerDir)
+ };
+
+ if ('mac' in builderOptions && 'target' in builderOptions.mac) {
+ if (builderOptions.mac.target.includes('mas')) {
+ this.platforms = ['darwin', 'mas'];
+ }
+ }
+
+ try {
+ this.log.debug('calling build from electron-builder');
+ await this.builder.dependency.build(Object.assign({
+ targets: this.prepareTargets(),
+ config: builderOptions
+ }, settings.builderCliOptions));
+
+ if (this.$.utils.exists(this.$.env.paths.electronApp.extractedNodeModules)) {
+ _shelljs.default.rm('-rf', this.$.env.paths.electronApp.extractedNodeModules);
+ }
+ } catch (e) {
+ this.log.error('error while building installer: ', e);
+ }
+ }
+ /**
+ * Moves node_modules out of the app because while the app will be packaged
+ * we do not want it to be there.
+ * @returns {Promise}
+ */
+
+
+ moveNodeModulesOut() {
+ return new Promise((resolve, reject) => {
+ this.log.debug('moving node_modules out, because we have them already in' + ' app.asar');
+ this.killMSBuild();
+ removeDir(this.$.env.paths.electronApp.tmpNodeModules).catch(e => reject(e)).then(() => {
+ _shelljs.default.config.fatal = true;
+ _shelljs.default.config.verbose = true;
+
+ try {
+ _shelljs.default.mv(this.$.env.paths.electronApp.nodeModules, this.$.env.paths.electronApp.tmpNodeModules);
+
+ _shelljs.default.config.reset();
+
+ return this.wait();
+ } catch (e) {
+ _shelljs.default.config.reset();
+
+ return Promise.reject(e);
+ }
+ }).catch(e => reject(e)).then(() => removeDir(this.$.env.paths.electronApp.nodeModules, 1000)).catch(e => reject(e)).then(() => this.wait()).catch(reject).then(resolve);
+ });
+ }
+
+}
+
+exports.default = InstallerBuilder;
+//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["removeDir","dirPath","delay","Promise","resolve","reject","setTimeout","rimraf","maxBusyTries","err","InstallerBuilder","constructor","$","log","Log","firstPass","lastRebuild","currentContext","installerDir","path","join","env","options","output","paths","platforms","init","builder","getDependency","defaultDependencies","appBuilder","yarn","require","getGypEnv","packageDependencies","prepareLastRebuildObject","arch","platform","process","productionDeps","createLazyProductionDeps","electronApp","root","frameworkInfo","version","getElectronVersion","useCustomDist","installOrRebuild","install","debug","desktop","getSettings","builderOptions","beforeBuild","context","Object","assign","platformMatches","nodeName","rebuild","warn","moveNodeModulesOut","catch","e","then","installLocalNodeModules","scaffold","createAppRoot","copySkeletonApp","packSkeletonToAsar","meteorAsar","desktopAsar","extracted","afterPack","filter","electronPlatformName","length","shell","config","fatal","utils","exists","extractedNodeModules","cp","getPackagedAppPath","mv","tmpNodeModules","nodeModules","reset","wait","killMSBuild","out","spawn","sync","stdout","toString","split","regex","RegExp","forEach","line","match","exec","lastIndex","packager","appInfo","productFilename","platformDir","appAsarPath","retries","self","check","fs","open","fd","code","closeSync","prepareTargets","ia32","allArchs","targets","win","push","dependency","Platform","WINDOWS","linux","LINUX","mac","MAC","os","isWindows","isLinux","createTargets","build","settings","error","exit","asar","npmRebuild","bind","electronVersion","directories","app","target","includes","builderCliOptions","rm","verbose"],"sources":["../lib/electronBuilder.js"],"sourcesContent":["// eslint-disable-next-line no-unused-vars\nimport regeneratorRuntime from 'regenerator-runtime/runtime';\nimport shell from 'shelljs';\nimport path from 'path';\nimport fs from 'fs';\nimport rimraf from 'rimraf';\nimport spawn from 'cross-spawn';\nimport Log from './log';\nimport defaultDependencies from './defaultDependencies';\n\n/**\n * Promisfied rimraf.\n *\n * @param {string} dirPath - path to the dir to be deleted\n * @param {number} delay - delay the task by ms\n * @returns {Promise<any>}\n */\nfunction removeDir(dirPath, delay = 0) {\n    return new Promise((resolve, reject) => {\n        setTimeout(() => {\n            rimraf(dirPath, {\n                maxBusyTries: 100\n            }, (err) => {\n                if (err) {\n                    reject(err);\n                } else {\n                    resolve();\n                }\n            });\n        }, delay);\n    });\n}\n\n/**\n * Wrapper for electron-builder.\n */\nexport default class InstallerBuilder {\n    /**\n     * @param {MeteorDesktop} $ - context\n     *\n     * @constructor\n     */\n    constructor($) {\n        this.log = new Log('electronBuilder');\n        this.$ = $;\n        this.firstPass = true;\n        this.lastRebuild = {};\n        this.currentContext = null;\n        this.installerDir = path.join(this.$.env.options.output, this.$.env.paths.installerDir);\n        this.platforms = [];\n    }\n\n    async init() {\n        this.builder = await this.$.getDependency('electron-builder', defaultDependencies['electron-builder']);\n        const appBuilder = await this.$.getDependency('app-builder-lib', defaultDependencies['electron-builder'], false);\n\n        this.yarn = require(path.join(appBuilder.path, 'out', 'util', 'yarn'));\n        this.getGypEnv = this.yarn.getGypEnv;\n        this.packageDependencies = require(path.join(appBuilder.path, 'out', 'util', 'packageDependencies'));\n    }\n\n    /**\n     * Prepares the last rebuild object for electron-builder.\n     *\n     * @param {string} arch\n     * @param {string} platform\n     * @returns {Object}\n     */\n    prepareLastRebuildObject(arch, platform = process.platform) {\n        const productionDeps = this.packageDependencies\n            .createLazyProductionDeps(this.$.env.paths.electronApp.root);\n        this.lastRebuild = {\n            frameworkInfo: { version: this.$.getElectronVersion(), useCustomDist: true },\n            platform,\n            arch,\n            productionDeps\n        };\n        return this.lastRebuild;\n    }\n\n    /**\n     * Calls npm rebuild from electron-builder.\n     * @param {string} arch\n     * @param {string} platform\n     * @param {boolean} install\n     * @returns {Promise}\n     */\n    async installOrRebuild(arch, platform = process.platform, install = false) {\n        this.log.debug(`calling installOrRebuild from electron-builder for arch ${arch}`);\n        this.prepareLastRebuildObject(arch, platform);\n        await this.yarn.installOrRebuild(this.$.desktop.getSettings().builderOptions || {},\n            this.$.env.paths.electronApp.root, this.lastRebuild, install);\n    }\n\n    /**\n     * Callback invoked before build is made. Ensures that app.asar have the right rebuilt\n     * node_modules.\n     *\n     * @param {Object} context\n     * @returns {Promise}\n     */\n    beforeBuild(context) {\n        this.currentContext = Object.assign({}, context);\n        return new Promise((resolve, reject) => {\n            const platformMatches = process.platform === context.platform.nodeName;\n            const rebuild = platformMatches && context.arch !== this.lastRebuild.arch;\n            if (!platformMatches) {\n                this.log.warn('skipping dependencies rebuild because platform is different, if you have native ' +\n                    'node modules as your app dependencies you should od the build on the target platform only');\n            }\n\n            if (!rebuild) {\n                this.moveNodeModulesOut()\n                    .catch(e => reject(e))\n                    .then(() => setTimeout(() => resolve(false), 2000));\n                // Timeout helps on Windows to clear the file locks.\n            } else {\n                // Lets rebuild the node_modules for different arch.\n                this.installOrRebuild(context.arch, context.platform.nodeName)\n                    .catch(e => reject(e))\n                    .then(() => this.$.electronApp.installLocalNodeModules(context.arch))\n                    .catch(e => reject(e))\n                    .then(() => {\n                        this.$.electronApp.scaffold.createAppRoot();\n                        this.$.electronApp.scaffold.copySkeletonApp();\n                        return this.$.electronApp.packSkeletonToAsar(\n                            [\n                                this.$.env.paths.electronApp.meteorAsar,\n                                this.$.env.paths.electronApp.desktopAsar,\n                                this.$.env.paths.electronApp.extracted\n                            ]\n                        );\n                    })\n                    .catch(e => reject(e))\n                    .then(() => this.moveNodeModulesOut())\n                    .catch(e => reject(e))\n                    .then(() => resolve(false));\n            }\n        });\n    }\n\n    /**\n     * Callback to be invoked after packing. Restores node_modules to the .desktop-build.\n     * @returns {Promise}\n     */\n    afterPack(context) {\n        this.platforms = this.platforms\n            .filter(platform => platform !== context.electronPlatformName);\n        if (this.platforms.length !== 0) {\n            return Promise.resolve();\n        }\n        return new Promise((resolve, reject) => {\n            shell.config.fatal = true;\n\n            if (this.$.utils.exists(this.$.env.paths.electronApp.extractedNodeModules)) {\n                this.log.debug('injecting extracted modules');\n                shell.cp(\n                    '-Rf',\n                    this.$.env.paths.electronApp.extractedNodeModules,\n                    path.join(this.getPackagedAppPath(context), 'node_modules')\n                );\n            }\n\n            this.log.debug('moving node_modules back');\n            // Move node_modules back.\n\n            try {\n                shell.mv(\n                    this.$.env.paths.electronApp.tmpNodeModules,\n                    this.$.env.paths.electronApp.nodeModules\n                );\n            } catch (e) {\n                reject(e);\n                return;\n            } finally {\n                shell.config.reset();\n            }\n\n            if (this.firstPass) {\n                this.firstPass = false;\n            }\n            this.log.debug('node_modules moved back');\n\n            this.wait()\n                .catch(e => reject(e))\n                .then(() => resolve());\n        });\n    }\n\n    /**\n     * This command kills orphaned MSBuild.exe processes.\n     * Sometime after native node_modules compilation they are still writing some logs,\n     * prevent node_modules from being deleted.\n     */\n    killMSBuild() {\n        if (this.currentContext.platform.nodeName !== 'win32') {\n            return;\n        }\n        try {\n            const out = spawn\n                .sync(\n                    'wmic',\n                    ['process', 'where', 'caption=\"MSBuild.exe\"', 'get', 'processid']\n                )\n                .stdout.toString('utf-8')\n                .split('\\n');\n\n            const regex = new RegExp(/(\\d+)/, 'gm');\n            // No we will check for those with the matching params.\n            out.forEach((line) => {\n                const match = regex.exec(line) || false;\n                if (match) {\n                    this.log.debug(`killing MSBuild.exe at pid: ${match[1]}`);\n                    spawn.sync('taskkill', ['/pid', match[1], '/f', '/t']);\n                }\n                regex.lastIndex = 0;\n            });\n        } catch (e) {\n            this.log.debug('kill MSBuild failed');\n        }\n    }\n\n    /**\n     * Returns the path to packaged app.\n     * @returns {string}\n     */\n    getPackagedAppPath(context = {}) {\n        if (this.currentContext.platform.nodeName === 'darwin') {\n            return path.join(\n                this.installerDir,\n                'mac',\n                `${context.packager.appInfo.productFilename}.app`,\n                'Contents', 'Resources', 'app'\n            );\n        }\n        const platformDir =\n            `${this.currentContext.platform.nodeName === 'win32' ? 'win' : 'linux'}-${this.currentContext.arch === 'ia32' ? 'ia32-' : ''}unpacked`;\n        return path.join(\n            this.installerDir,\n            platformDir,\n            'resources', 'app'\n        );\n    }\n\n    /**\n     * On Windows it waits for the app.asar in the packed app to be free (no file locks).\n     * @returns {*}\n     */\n    wait() {\n        if (this.currentContext.platform.nodeName !== 'win32') {\n            return Promise.resolve();\n        }\n        const appAsarPath = path.join(\n            this.getPackagedAppPath(),\n            'app.asar'\n        );\n        let retries = 0;\n        const self = this;\n        return new Promise((resolve, reject) => {\n            function check() {\n                fs.open(appAsarPath, 'r+', (err, fd) => {\n                    retries += 1;\n                    if (err) {\n                        if (err.code !== 'ENOENT') {\n                            self.log.debug(`waiting for app.asar to be readable, ${'code' in err ? `currently reading it returns ${err.code}` : ''}`);\n                            if (retries < 6) {\n                                setTimeout(() => check(), 4000);\n                            } else {\n                                reject(`file is locked: ${appAsarPath}`);\n                            }\n                        } else {\n                            resolve();\n                        }\n                    } else {\n                        fs.closeSync(fd);\n                        resolve();\n                    }\n                });\n            }\n            check();\n        });\n    }\n\n    /**\n     * Prepares the target object passed to the electron-builder.\n     *\n     * @returns {Map<Platform, Map<Arch, Array<string>>>}\n     */\n    prepareTargets() {\n        let arch = this.$.env.options.ia32 ? 'ia32' : 'x64';\n        arch = this.$.env.options.allArchs ? 'all' : arch;\n\n        const targets = [];\n\n        if (this.$.env.options.win) {\n            targets.push(this.builder.dependency.Platform.WINDOWS);\n        }\n        if (this.$.env.options.linux) {\n            targets.push(this.builder.dependency.Platform.LINUX);\n        }\n        if (this.$.env.options.mac) {\n            targets.push(this.builder.dependency.Platform.MAC);\n        }\n\n        if (targets.length === 0) {\n            if (this.$.env.os.isWindows) {\n                targets.push(this.builder.dependency.Platform.WINDOWS);\n            } else if (this.$.env.os.isLinux) {\n                targets.push(this.builder.dependency.Platform.LINUX);\n            } else {\n                targets.push(this.builder.dependency.Platform.MAC);\n            }\n        }\n        return this.builder.dependency.createTargets(targets, null, arch);\n    }\n\n    async build() {\n        const settings = this.$.desktop.getSettings();\n        if (!('builderOptions' in settings)) {\n            this.log.error(\n                'no builderOptions in settings.json, aborting'\n            );\n            process.exit(1);\n        }\n\n        const builderOptions = Object.assign({}, settings.builderOptions);\n\n        builderOptions.asar = false;\n        builderOptions.npmRebuild = true;\n\n        builderOptions.beforeBuild = this.beforeBuild.bind(this);\n        builderOptions.afterPack = this.afterPack.bind(this);\n        builderOptions.electronVersion = this.$.getElectronVersion();\n\n        builderOptions.directories = {\n            app: this.$.env.paths.electronApp.root,\n            output: path.join(this.$.env.options.output, this.$.env.paths.installerDir)\n        };\n\n        if ('mac' in builderOptions && 'target' in builderOptions.mac) {\n            if (builderOptions.mac.target.includes('mas')) {\n                this.platforms = ['darwin', 'mas'];\n            }\n        }\n\n        try {\n            this.log.debug('calling build from electron-builder');\n            await this.builder.dependency.build(Object.assign({\n                targets: this.prepareTargets(),\n                config: builderOptions\n            }, settings.builderCliOptions));\n\n            if (this.$.utils.exists(this.$.env.paths.electronApp.extractedNodeModules)) {\n                shell.rm('-rf', this.$.env.paths.electronApp.extractedNodeModules);\n            }\n        } catch (e) {\n            this.log.error('error while building installer: ', e);\n        }\n    }\n\n    /**\n     * Moves node_modules out of the app because while the app will be packaged\n     * we do not want it to be there.\n     * @returns {Promise<any>}\n     */\n    moveNodeModulesOut() {\n        return new Promise((resolve, reject) => {\n            this.log.debug('moving node_modules out, because we have them already in' +\n                ' app.asar');\n            this.killMSBuild();\n            removeDir(this.$.env.paths.electronApp.tmpNodeModules)\n                .catch(e => reject(e))\n                .then(() => {\n                    shell.config.fatal = true;\n                    shell.config.verbose = true;\n                    try {\n                        shell.mv(\n                            this.$.env.paths.electronApp.nodeModules,\n                            this.$.env.paths.electronApp.tmpNodeModules\n                        );\n                        shell.config.reset();\n                        return this.wait();\n                    } catch (e) {\n                        shell.config.reset();\n                        return Promise.reject(e);\n                    }\n                })\n                .catch(e => reject(e))\n                .then(() => removeDir(this.$.env.paths.electronApp.nodeModules, 1000))\n                .catch(e => reject(e))\n                .then(() => this.wait())\n                .catch(reject)\n                .then(resolve);\n        });\n    }\n}\n"],"mappings":"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"}
\ No newline at end of file
diff --git a/dist/env.js b/dist/env.js
new file mode 100644
index 00000000..8f8fd133
--- /dev/null
+++ b/dist/env.js
@@ -0,0 +1,239 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = void 0;
+
+var _path = _interopRequireDefault(require("path"));
+
+var _os = _interopRequireDefault(require("os"));
+
+var _assignIn = _interopRequireDefault(require("lodash/assignIn"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+const {
+ join
+} = _path.default;
+/**
+ * @class
+ * @property {packagePaths} paths
+ */
+
+class Env {
+ constructor(input, output, options) {
+ this.options = options;
+
+ if (this.isProductionBuild()) {
+ process.env.NODE_ENV = 'production';
+ }
+
+ this.sys = {
+ platform: process.platform,
+ arch: process.arch
+ }; // Operational System.
+
+ this.os = {
+ isWindows: process.platform === 'win32',
+ isLinux: process.platform === 'linux',
+ isOsx: process.platform === 'darwin'
+ };
+ this.stdio = 'inherit';
+ this.os.name = this.sys.platform === 'darwin' ? 'osx' : this.sys.platform;
+ this.os.home = process.env[this.os.isWindows ? 'USERPROFILE' : 'HOME'];
+ this.os.tmp = _os.default.tmpdir();
+ /** @type {packagePaths} */
+
+ this.paths = {};
+ /** @type {meteorDesktopPaths} */
+
+ this.paths.meteorDesktop = {
+ root: _path.default.resolve(__dirname, '..')
+ };
+ this.paths.meteorDesktop.skeleton = join(this.paths.meteorDesktop.root, 'skeleton');
+ /** @type {meteorAppPaths} */
+
+ this.paths.meteorApp = {
+ root: input
+ };
+ /** @type {desktopPaths} */
+
+ this.paths.desktop = {
+ rootName: '.desktop',
+ root: join(this.paths.meteorApp.root, '.desktop')
+ };
+ (0, _assignIn.default)(this.paths.desktop, {
+ modules: join(this.paths.desktop.root, 'modules'),
+ import: join(this.paths.desktop.root, 'import'),
+ assets: join(this.paths.desktop.root, 'assets'),
+ settings: join(this.paths.desktop.root, 'settings.json'),
+ desktop: join(this.paths.desktop.root, 'desktop.js')
+ });
+ this.paths.desktop.splashScreen = join(this.paths.desktop.assets, 'splashScreen.png');
+ this.paths.desktop.loadingGif = join(this.paths.desktop.assets, 'loading.gif');
+ this.paths.desktop.meteorIco = join(this.paths.desktop.assets, 'meteor.ico');
+ /** @type {electronAppPaths} */
+
+ this.paths.electronApp = {
+ rootName: 'desktop-build'
+ };
+ this.paths.electronApp.root = join(this.paths.meteorApp.root, '.meteor', this.paths.electronApp.rootName);
+ this.paths.electronApp.tmpNodeModules = join(this.paths.meteorApp.root, '.meteor', '.desktop_node_modules');
+ this.paths.cache = join(this.paths.meteorApp.root, '.meteor', 'local', 'desktop-cache');
+ this.paths.electronApp.extractedNodeModules = join(this.paths.meteorApp.root, '.meteor', '.desktop_extracted_node_modules');
+ this.paths.electronApp.extractedNodeModulesBin = join(this.paths.electronApp.extractedNodeModules, '.bin');
+ this.paths.electronApp.appRoot = join(this.paths.electronApp.root, 'app');
+ (0, _assignIn.default)(this.paths.electronApp, {
+ app: join(this.paths.electronApp.appRoot, 'app.js'),
+ cordova: join(this.paths.electronApp.appRoot, 'cordova.js'),
+ index: join(this.paths.electronApp.appRoot, 'index.js'),
+ preload: join(this.paths.electronApp.appRoot, 'preload.js'),
+ modules: join(this.paths.electronApp.appRoot, 'modules'),
+ desktopAsar: join(this.paths.electronApp.root, 'desktop.asar'),
+ extracted: join(this.paths.electronApp.root, 'extracted'),
+ appAsar: join(this.paths.electronApp.root, 'app.asar'),
+ import: join(this.paths.electronApp.root, 'import'),
+ assets: join(this.paths.electronApp.root, 'assets'),
+ packageJson: join(this.paths.electronApp.root, 'package.json'),
+ settings: join(this.paths.electronApp.root, 'settings.json'),
+ desktop: join(this.paths.electronApp.root, 'desktop.js'),
+ desktopTmp: join(this.paths.electronApp.root, '__desktop'),
+ nodeModules: join(this.paths.electronApp.root, 'node_modules'),
+ meteorAsar: join(this.paths.electronApp.root, 'meteor.asar'),
+ meteorApp: join(this.paths.electronApp.root, 'meteor'),
+ meteorAppIndex: join(this.paths.electronApp.root, 'meteor', 'index.html'),
+ meteorAppProgramJson: join(this.paths.electronApp.root, 'meteor', 'program.json'),
+ skeleton: join(this.paths.electronApp.root, 'skeleton')
+ });
+ (0, _assignIn.default)(this.paths.meteorApp, {
+ platforms: join(this.paths.meteorApp.root, '.meteor', 'platforms'),
+ packages: join(this.paths.meteorApp.root, '.meteor', 'packages'),
+ versions: join(this.paths.meteorApp.root, '.meteor', 'versions'),
+ release: join(this.paths.meteorApp.root, '.meteor', 'release'),
+ packageJson: join(this.paths.meteorApp.root, 'package.json'),
+ gitIgnore: join(this.paths.meteorApp.root, '.meteor', '.gitignore'),
+ cordovaBuild: join(this.paths.meteorApp.root, '.meteor', 'local', 'cordova-build', 'www', 'application'),
+ webCordova: join(this.paths.meteorApp.root, '.meteor', 'local', 'build', 'programs', 'web.cordova')
+ });
+ (0, _assignIn.default)(this.paths.meteorApp, {
+ cordovaBuildIndex: join(this.paths.meteorApp.cordovaBuild, 'index.html'),
+ cordovaBuildProgramJson: join(this.paths.meteorApp.cordovaBuild, 'program.json')
+ });
+ (0, _assignIn.default)(this.paths.meteorApp, {
+ webCordovaProgramJson: join(this.paths.meteorApp.webCordova, 'program.json')
+ });
+ /** @type {desktopTmpPaths} */
+
+ this.paths.desktopTmp = {
+ root: join(this.paths.electronApp.root, '__desktop')
+ };
+ (0, _assignIn.default)(this.paths.desktopTmp, {
+ modules: join(this.paths.desktopTmp.root, 'modules'),
+ settings: join(this.paths.desktopTmp.root, 'settings.json')
+ });
+ this.paths.packageDir = '.desktop-package';
+ this.paths.installerDir = '.desktop-installer'; // Scaffold
+
+ this.paths.scaffold = join(__dirname, '..', 'scaffold');
+ }
+ /**
+ * @returns {boolean|*}
+ * @public
+ */
+
+
+ isProductionBuild() {
+ return !!('production' in this.options && this.options.production);
+ }
+
+}
+
+exports.default = Env;
+module.exports = Env;
+/**
+ * @typedef {Object} desktopPaths
+ * @property {string} rootName
+ * @property {string} root
+ * @property {string} modules
+ * @property {string} import
+ * @property {string} assets
+ * @property {string} settings
+ * @property {string} desktop
+ * @property {string} splashScreen
+ * @property {string} loadingGif
+ * @property {string} meteorIco
+ */
+
+/**
+ * @typedef {Object} meteorAppPaths
+ * @property {string} root
+ * @property {string} platforms
+ * @property {string} release
+ * @property {string} packages
+ * @property {string} versions
+ * @property {string} gitIgnore
+ * @property {string} packageJson
+ * @property {string} cordovaBuild
+ * @property {string} cordovaBuildIndex
+ * @property {string} cordovaBuildProgramJson
+ * @property {string} webCordova
+ * @property {string} webCordovaIndex
+ * @property {string} webCordovaProgramJson
+ */
+
+/**
+ * @typedef {Object} electronAppPaths
+ * @property {string} rootName
+ * @property {string} root
+ * @property {Object} appRoot
+ * @property {string} appRoot.cordova
+ * @property {string} appRoot.index
+ * @property {string} appRoot.app
+ * @property {string} appRoot.modules
+ * @property {string} desktopAsar
+ * @property {string} extracted
+ * @property {string} appAsar
+ * @property {string} preload
+ * @property {string} import
+ * @property {string} assets
+ * @property {string} gitIgnore
+ * @property {string} packageJson
+ * @property {string} settings
+ * @property {string} desktop
+ * @property {string} desktopTmp
+ * @property {string} nodeModules
+ * @property {string} meteorAsar
+ * @property {string} meteorApp
+ * @property {string} meteorAppIndex
+ * @property {string} meteorAppProgramJson
+ * @property {string} skeleton
+ * @property {string} tmpNodeModules
+ * @property {string} extractedNodeModules
+ * @property {string} extractedNodeModulesBin
+ */
+
+/**
+ * @typedef {Object} desktopTmpPaths
+ * @property {string} root
+ * @property {string} modules
+ * @property {string} settings
+ */
+
+/**
+ * @typedef {Object} meteorDesktopPaths
+ * @property {string} root
+ * @property {string} skeleton
+ */
+
+/**
+ * @typedef {Object} packagePaths
+ * @property {meteorAppPaths} meteorApp
+ * @property {desktopPaths} desktop
+ * @property {electronAppPaths} electronApp
+ * @property {desktopTmpPaths} desktopTmp
+ * @property {meteorDesktopPaths} meteorDesktop
+ * @property {string} packageDir
+ * @property {string} scaffold
+ */
+//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["join","path","Env","constructor","input","output","options","isProductionBuild","process","env","NODE_ENV","sys","platform","arch","os","isWindows","isLinux","isOsx","stdio","name","home","tmp","tmpdir","paths","meteorDesktop","root","resolve","__dirname","skeleton","meteorApp","desktop","rootName","assignIn","modules","import","assets","settings","splashScreen","loadingGif","meteorIco","electronApp","tmpNodeModules","cache","extractedNodeModules","extractedNodeModulesBin","appRoot","app","cordova","index","preload","desktopAsar","extracted","appAsar","packageJson","desktopTmp","nodeModules","meteorAsar","meteorAppIndex","meteorAppProgramJson","platforms","packages","versions","release","gitIgnore","cordovaBuild","webCordova","cordovaBuildIndex","cordovaBuildProgramJson","webCordovaProgramJson","packageDir","installerDir","scaffold","production","module","exports"],"sources":["../lib/env.js"],"sourcesContent":["import path from 'path';\nimport os from 'os';\nimport assignIn from 'lodash/assignIn';\n\nconst { join } = path;\n\n/**\n * @class\n * @property {packagePaths} paths\n */\nexport default class Env {\n    constructor(input, output, options) {\n        this.options = options;\n\n        if (this.isProductionBuild()) {\n            process.env.NODE_ENV = 'production';\n        }\n\n        this.sys = {\n            platform: process.platform,\n            arch: process.arch\n        };\n\n        // Operational System.\n        this.os = {\n            isWindows: (process.platform === 'win32'),\n            isLinux: (process.platform === 'linux'),\n            isOsx: (process.platform === 'darwin')\n\n        };\n        this.stdio = 'inherit';\n\n        this.os.name = (this.sys.platform === 'darwin' ? 'osx' : this.sys.platform);\n        this.os.home = process.env[(this.os.isWindows ? 'USERPROFILE' : 'HOME')];\n        this.os.tmp = os.tmpdir();\n\n        /** @type {packagePaths} */\n        this.paths = {};\n\n        /** @type {meteorDesktopPaths} */\n        this.paths.meteorDesktop = {\n            root: path.resolve(__dirname, '..')\n        };\n\n        this.paths.meteorDesktop.skeleton = join(this.paths.meteorDesktop.root, 'skeleton');\n\n        /** @type {meteorAppPaths} */\n        this.paths.meteorApp = {\n            root: input\n        };\n\n        /** @type {desktopPaths} */\n        this.paths.desktop = {\n            rootName: '.desktop',\n            root: join(this.paths.meteorApp.root, '.desktop')\n        };\n\n        assignIn(this.paths.desktop, {\n            modules: join(this.paths.desktop.root, 'modules'),\n            import: join(this.paths.desktop.root, 'import'),\n            assets: join(this.paths.desktop.root, 'assets'),\n            settings: join(this.paths.desktop.root, 'settings.json'),\n            desktop: join(this.paths.desktop.root, 'desktop.js')\n        });\n\n        this.paths.desktop.splashScreen = join(this.paths.desktop.assets, 'splashScreen.png');\n        this.paths.desktop.loadingGif = join(this.paths.desktop.assets, 'loading.gif');\n        this.paths.desktop.meteorIco = join(this.paths.desktop.assets, 'meteor.ico');\n\n        /** @type {electronAppPaths} */\n        this.paths.electronApp = {\n            rootName: 'desktop-build',\n        };\n        this.paths.electronApp.root =\n            join(this.paths.meteorApp.root, '.meteor', this.paths.electronApp.rootName);\n\n        this.paths.electronApp.tmpNodeModules =\n            join(this.paths.meteorApp.root, '.meteor', '.desktop_node_modules');\n\n        this.paths.cache =\n            join(this.paths.meteorApp.root, '.meteor', 'local', 'desktop-cache');\n\n        this.paths.electronApp.extractedNodeModules =\n            join(this.paths.meteorApp.root, '.meteor', '.desktop_extracted_node_modules');\n\n        this.paths.electronApp.extractedNodeModulesBin =\n            join(this.paths.electronApp.extractedNodeModules, '.bin');\n\n\n        this.paths.electronApp.appRoot =\n            join(this.paths.electronApp.root, 'app');\n\n        assignIn(this.paths.electronApp, {\n            app: join(this.paths.electronApp.appRoot, 'app.js'),\n            cordova: join(this.paths.electronApp.appRoot, 'cordova.js'),\n            index: join(this.paths.electronApp.appRoot, 'index.js'),\n            preload: join(this.paths.electronApp.appRoot, 'preload.js'),\n            modules: join(this.paths.electronApp.appRoot, 'modules'),\n            desktopAsar: join(this.paths.electronApp.root, 'desktop.asar'),\n            extracted: join(this.paths.electronApp.root, 'extracted'),\n            appAsar: join(this.paths.electronApp.root, 'app.asar'),\n            import: join(this.paths.electronApp.root, 'import'),\n            assets: join(this.paths.electronApp.root, 'assets'),\n            packageJson: join(this.paths.electronApp.root, 'package.json'),\n            settings: join(this.paths.electronApp.root, 'settings.json'),\n            desktop: join(this.paths.electronApp.root, 'desktop.js'),\n            desktopTmp: join(this.paths.electronApp.root, '__desktop'),\n            nodeModules: join(this.paths.electronApp.root, 'node_modules'),\n            meteorAsar: join(this.paths.electronApp.root, 'meteor.asar'),\n            meteorApp: join(this.paths.electronApp.root, 'meteor'),\n            meteorAppIndex: join(this.paths.electronApp.root, 'meteor', 'index.html'),\n            meteorAppProgramJson: join(this.paths.electronApp.root, 'meteor', 'program.json'),\n            skeleton: join(this.paths.electronApp.root, 'skeleton')\n        });\n\n        assignIn(this.paths.meteorApp, {\n            platforms: join(this.paths.meteorApp.root, '.meteor', 'platforms'),\n            packages: join(this.paths.meteorApp.root, '.meteor', 'packages'),\n            versions: join(this.paths.meteorApp.root, '.meteor', 'versions'),\n            release: join(this.paths.meteorApp.root, '.meteor', 'release'),\n            packageJson: join(this.paths.meteorApp.root, 'package.json'),\n            gitIgnore: join(this.paths.meteorApp.root, '.meteor', '.gitignore'),\n            cordovaBuild: join(\n                this.paths.meteorApp.root,\n                '.meteor',\n                'local',\n                'cordova-build',\n                'www',\n                'application'\n            ),\n            webCordova: join(\n                this.paths.meteorApp.root,\n                '.meteor',\n                'local',\n                'build',\n                'programs',\n                'web.cordova'\n            )\n        });\n\n        assignIn(this.paths.meteorApp, {\n            cordovaBuildIndex: join(\n                this.paths.meteorApp.cordovaBuild, 'index.html'\n            ),\n            cordovaBuildProgramJson: join(\n                this.paths.meteorApp.cordovaBuild, 'program.json'\n            )\n        });\n\n        assignIn(this.paths.meteorApp, {\n            webCordovaProgramJson: join(\n                this.paths.meteorApp.webCordova, 'program.json'\n            )\n        });\n\n\n        /** @type {desktopTmpPaths} */\n        this.paths.desktopTmp = {\n            root: join(this.paths.electronApp.root, '__desktop'),\n        };\n\n        assignIn(this.paths.desktopTmp, {\n            modules: join(this.paths.desktopTmp.root, 'modules'),\n            settings: join(this.paths.desktopTmp.root, 'settings.json')\n        });\n\n        this.paths.packageDir = '.desktop-package';\n        this.paths.installerDir = '.desktop-installer';\n\n        // Scaffold\n        this.paths.scaffold = join(__dirname, '..', 'scaffold');\n    }\n\n    /**\n     * @returns {boolean|*}\n     * @public\n     */\n    isProductionBuild() {\n        return !!('production' in this.options && this.options.production);\n    }\n}\n\nmodule.exports = Env;\n\n/**\n * @typedef {Object} desktopPaths\n * @property {string} rootName\n * @property {string} root\n * @property {string} modules\n * @property {string} import\n * @property {string} assets\n * @property {string} settings\n * @property {string} desktop\n * @property {string} splashScreen\n * @property {string} loadingGif\n * @property {string} meteorIco\n */\n\n/**\n * @typedef {Object} meteorAppPaths\n * @property {string} root\n * @property {string} platforms\n * @property {string} release\n * @property {string} packages\n * @property {string} versions\n * @property {string} gitIgnore\n * @property {string} packageJson\n * @property {string} cordovaBuild\n * @property {string} cordovaBuildIndex\n * @property {string} cordovaBuildProgramJson\n * @property {string} webCordova\n * @property {string} webCordovaIndex\n * @property {string} webCordovaProgramJson\n */\n\n/**\n * @typedef {Object} electronAppPaths\n * @property {string} rootName\n * @property {string} root\n * @property {Object} appRoot\n * @property {string} appRoot.cordova\n * @property {string} appRoot.index\n * @property {string} appRoot.app\n * @property {string} appRoot.modules\n * @property {string} desktopAsar\n * @property {string} extracted\n * @property {string} appAsar\n * @property {string} preload\n * @property {string} import\n * @property {string} assets\n * @property {string} gitIgnore\n * @property {string} packageJson\n * @property {string} settings\n * @property {string} desktop\n * @property {string} desktopTmp\n * @property {string} nodeModules\n * @property {string} meteorAsar\n * @property {string} meteorApp\n * @property {string} meteorAppIndex\n * @property {string} meteorAppProgramJson\n * @property {string} skeleton\n * @property {string} tmpNodeModules\n * @property {string} extractedNodeModules\n * @property {string} extractedNodeModulesBin\n */\n\n/**\n * @typedef {Object} desktopTmpPaths\n * @property {string} root\n * @property {string} modules\n * @property {string} settings\n */\n\n/**\n * @typedef {Object} meteorDesktopPaths\n * @property {string} root\n * @property {string} skeleton\n */\n\n/**\n * @typedef {Object} packagePaths\n * @property {meteorAppPaths} meteorApp\n * @property {desktopPaths} desktop\n * @property {electronAppPaths} electronApp\n * @property {desktopTmpPaths} desktopTmp\n * @property {meteorDesktopPaths} meteorDesktop\n * @property {string} packageDir\n * @property {string} scaffold\n */\n"],"mappings":"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"}
\ No newline at end of file
diff --git a/dist/index.js b/dist/index.js
new file mode 100644
index 00000000..44c7cecc
--- /dev/null
+++ b/dist/index.js
@@ -0,0 +1,247 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = _exports;
+
+var _runtime = _interopRequireDefault(require("regenerator-runtime/runtime"));
+
+var _fs = _interopRequireDefault(require("fs"));
+
+var _path = _interopRequireDefault(require("path"));
+
+var _shelljs = _interopRequireDefault(require("shelljs"));
+
+var _env = _interopRequireDefault(require("./env"));
+
+var _electron = _interopRequireDefault(require("./electron"));
+
+var _log = _interopRequireDefault(require("./log"));
+
+var _desktop = _interopRequireDefault(require("./desktop"));
+
+var _electronApp = _interopRequireDefault(require("./electronApp"));
+
+var _meteorApp = _interopRequireDefault(require("./meteorApp"));
+
+var _electronBuilder = _interopRequireDefault(require("./electronBuilder"));
+
+var _packager = _interopRequireDefault(require("./packager"));
+
+var _utils = _interopRequireDefault(require("./utils"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+// eslint-disable-next-line no-unused-vars
+_shelljs.default.config.fatal = true;
+/**
+ * Main entity.
+ * @class
+ * @property {Env} env
+ * @property {Electron} electron
+ * @property {InstallerBuilder} installerBuilder
+ * @property {ElectronApp} electronApp
+ * @property {Desktop} desktop
+ * @property {MeteorApp} meteorApp
+ */
+
+class MeteorDesktop {
+ /**
+ * @param {string} input - Meteor app dir
+ * @param {string} output - output dir for bundle/package/installer
+ * @param {Object} options - options from cli.js
+ * @param {Object} dependencies - dependencies object
+ * @constructor
+ */
+ constructor(input, output, options, dependencies) {
+ const Log = dependencies.log;
+ this.log = new Log('index');
+ this.version = this.getVersion();
+ this.log.info('initializing');
+ this.env = new _env.default(input, output, options);
+ this.electron = new _electron.default(this);
+ this.electronBuilder = new _electronBuilder.default(this);
+ this.electronApp = new _electronApp.default(this);
+ this.desktop = new _desktop.default(this);
+ this.meteorApp = new _meteorApp.default(this);
+ this.utils = _utils.default;
+ }
+ /**
+ * Tries to read the version from our own package.json.
+ *
+ * @returns {string}
+ */
+
+
+ getVersion() {
+ if (this.version) {
+ return this.version;
+ }
+
+ let version = null;
+
+ try {
+ ({
+ version
+ } = JSON.parse(_fs.default.readFileSync(_path.default.join(__dirname, '..', 'package.json'), 'UTF-8')));
+ } catch (e) {
+ this.log.error(`error while trying to read ${_path.default.join(__dirname, 'package.json')}`, e);
+ process.exit(1);
+ }
+
+ if (process.env.PLUGIN_VERSION && (version.includes('rc') || version.includes('beta') || version.includes('alpha'))) {
+ version = process.env.PLUGIN_VERSION;
+ }
+
+ return version;
+ }
+ /**
+ * Tries to read the version from our own package.json.
+ *
+ * @returns {string}
+ */
+
+
+ getElectronVersion() {
+ let version = null;
+
+ try {
+ const {
+ dependencies = {},
+ devDependencies = {}
+ } = JSON.parse(_fs.default.readFileSync(_path.default.join(this.env.paths.meteorApp.root, 'package.json'), 'UTF-8'));
+
+ if (!('electron' in dependencies) && !('electron' in devDependencies)) {
+ this.log.error('electron not found in meteor project dependencies');
+ process.exit(1);
+ }
+
+ version = dependencies.electron || devDependencies.electron;
+
+ if (this.electronApp.depsManager.checks.version.regex.test(version)) {
+ ({
+ version
+ } = JSON.parse(_fs.default.readFileSync(_path.default.join(this.env.paths.meteorApp.root, 'node_modules', 'electron', 'package.json'), 'UTF-8')));
+ }
+ } catch (e) {
+ this.log.error(`error while trying to read ${_path.default.join(this.env.paths.meteorApp.root, 'package.json')}`, e);
+ process.exit(1);
+ }
+
+ return version;
+ }
+
+ async init() {
+ this.desktop.scaffold();
+ this.meteorApp.updateGitIgnore();
+ await this.electronApp.init();
+ }
+
+ async buildInstaller(throwError = false) {
+ this.env.options.installerBuild = true;
+ await this.electronApp.build();
+
+ try {
+ await this.electronBuilder.build();
+ } catch (e) {
+ this.log.error('error occurred while building installer', e);
+
+ if (throwError) {
+ throw new Error(e);
+ }
+ }
+ }
+
+ async run() {
+ await this.electronApp.build(true);
+ }
+
+ async build() {
+ await this.electronApp.build();
+ }
+
+ justRun() {
+ this.electron.run();
+ }
+
+ async runPackager() {
+ this.packager = new _packager.default(this);
+ await this.packager.init();
+ await this.electronApp.build();
+ this.packager.packageApp().catch(e => {
+ this.log.error(`while trying to build a package an error occurred: ${e}`);
+ });
+ }
+
+ async getDependency(name, version, declarationCheck = true) {
+ if (declarationCheck) {
+ try {
+ const {
+ dependencies = {},
+ devDependencies = {}
+ } = JSON.parse(_fs.default.readFileSync(_path.default.join(this.env.paths.meteorApp.root, 'package.json'), 'UTF-8'));
+
+ if (!(name in dependencies) && !(name in devDependencies)) {
+ await this.meteorApp.runNpm(['i', '-D', '-E', '--only=dev', `${name}@${version}`], 'inherit');
+ }
+ } catch (e) {
+ this.log.error(`could no read ${_path.default.join(this.env.paths.meteorApp.root, 'package.json')}`, e);
+ process.exit(1);
+ }
+ }
+
+ const dependencyPath = _path.default.join(this.env.paths.meteorApp.root, 'node_modules', name);
+
+ let dependency = null;
+
+ try {
+ dependency = require(dependencyPath);
+ } catch (e) {
+ if (declarationCheck) {
+ this.log.warn(`could not find ${name}, installing the default version for you: ${name}@${version}`);
+
+ try {
+ await this.meteorApp.runNpm(['i', '-D', '-E', '--only=dev', `${name}@${version}`], 'inherit');
+ } catch (err) {
+ this.log.error(err);
+ process.exit(1);
+ }
+ } else {
+ this.log.warn(`could not find ${name}, exiting`);
+ process.exit(1);
+ }
+ } finally {
+ if (!dependency) {
+ dependency = require(dependencyPath);
+ }
+ }
+
+ const dependencyVersion = require(_path.default.join(dependencyPath, 'package.json')).version;
+
+ if (dependencyVersion !== version) {
+ if (dependencyVersion.split('.')[0] !== version.split('.')[0]) {
+ this.log.warn(`you are using a ${name}@${dependencyVersion} while the recommended version is ` + `${version}, the compatibility version is different, use at your own risk, be sure to report ` + 'that when submitting issues');
+ } else {
+ this.log.warn(`you are using a ${name}@${dependencyVersion} while the recommended version is ` + `${version}, be sure to report that when submitting issues`);
+ }
+ }
+
+ return {
+ dependency,
+ path: dependencyPath
+ };
+ }
+
+}
+
+function _exports(input, output, options, {
+ log = _log.default
+} = {
+ log: _log.default
+}) {
+ return new MeteorDesktop(input, output, options, {
+ log
+ });
+}
+//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["shell","config","fatal","MeteorDesktop","constructor","input","output","options","dependencies","Log","log","version","getVersion","info","env","Env","electron","Electron","electronBuilder","ElectronBuilder","electronApp","ElectronApp","desktop","Desktop","meteorApp","MeteorApp","utils","JSON","parse","fs","readFileSync","path","join","__dirname","e","error","process","exit","PLUGIN_VERSION","includes","getElectronVersion","devDependencies","paths","root","depsManager","checks","regex","test","init","scaffold","updateGitIgnore","buildInstaller","throwError","installerBuild","build","Error","run","justRun","runPackager","packager","Packager","packageApp","catch","getDependency","name","declarationCheck","runNpm","dependencyPath","dependency","require","warn","err","dependencyVersion","split","exports","Logger"],"sources":["../lib/index.js"],"sourcesContent":["// eslint-disable-next-line no-unused-vars\nimport regeneratorRuntime from 'regenerator-runtime/runtime';\nimport fs from 'fs';\nimport path from 'path';\nimport shell from 'shelljs';\nimport Env from './env';\nimport Electron from './electron';\nimport Logger from './log';\nimport Desktop from './desktop';\nimport ElectronApp from './electronApp';\nimport MeteorApp from './meteorApp';\nimport ElectronBuilder from './electronBuilder';\nimport Packager from './packager';\nimport utils from './utils';\n\nshell.config.fatal = true;\n\n/**\n * Main entity.\n * @class\n * @property {Env} env\n * @property {Electron} electron\n * @property {InstallerBuilder} installerBuilder\n * @property {ElectronApp} electronApp\n * @property {Desktop} desktop\n * @property {MeteorApp} meteorApp\n */\nclass MeteorDesktop {\n    /**\n     * @param {string} input        - Meteor app dir\n     * @param {string} output       - output dir for bundle/package/installer\n     * @param {Object} options      - options from cli.js\n     * @param {Object} dependencies - dependencies object\n     * @constructor\n     */\n    constructor(input, output, options, dependencies) {\n        const Log = dependencies.log;\n        this.log = new Log('index');\n        this.version = this.getVersion();\n\n        this.log.info('initializing');\n\n        this.env = new Env(input, output, options);\n        this.electron = new Electron(this);\n        this.electronBuilder = new ElectronBuilder(this);\n        this.electronApp = new ElectronApp(this);\n        this.desktop = new Desktop(this);\n        this.meteorApp = new MeteorApp(this);\n        this.utils = utils;\n    }\n\n    /**\n     * Tries to read the version from our own package.json.\n     *\n     * @returns {string}\n     */\n    getVersion() {\n        if (this.version) {\n            return this.version;\n        }\n\n        let version = null;\n        try {\n            ({ version } = JSON.parse(\n                fs.readFileSync(path.join(__dirname, '..', 'package.json'), 'UTF-8')\n            ));\n        } catch (e) {\n            this.log.error(`error while trying to read ${path.join(__dirname, 'package.json')}`, e);\n            process.exit(1);\n        }\n        if (process.env.PLUGIN_VERSION &&\n            (version.includes('rc') || version.includes('beta') || version.includes('alpha'))\n        ) {\n            version = process.env.PLUGIN_VERSION;\n        }\n        return version;\n    }\n\n    /**\n     * Tries to read the version from our own package.json.\n     *\n     * @returns {string}\n     */\n    getElectronVersion() {\n        let version = null;\n        try {\n            const { dependencies = {}, devDependencies = {} } = JSON.parse(\n                fs.readFileSync(path.join(this.env.paths.meteorApp.root, 'package.json'), 'UTF-8')\n            );\n            if (!('electron' in dependencies) && !('electron' in devDependencies)) {\n                this.log.error('electron not found in meteor project dependencies');\n                process.exit(1);\n            }\n            version = dependencies.electron || devDependencies.electron;\n            if (this.electronApp.depsManager.checks.version.regex.test(version)) {\n                ({ version } = JSON.parse(\n                    fs.readFileSync(path.join(this.env.paths.meteorApp.root, 'node_modules', 'electron', 'package.json'), 'UTF-8')\n                ));\n            }\n        } catch (e) {\n            this.log.error(`error while trying to read ${path.join(this.env.paths.meteorApp.root, 'package.json')}`, e);\n            process.exit(1);\n        }\n        return version;\n    }\n\n    async init() {\n        this.desktop.scaffold();\n        this.meteorApp.updateGitIgnore();\n        await this.electronApp.init();\n    }\n\n    async buildInstaller(throwError = false) {\n        this.env.options.installerBuild = true;\n        await this.electronApp.build();\n        try {\n            await this.electronBuilder.build();\n        } catch (e) {\n            this.log.error('error occurred while building installer', e);\n            if (throwError) {\n                throw new Error(e);\n            }\n        }\n    }\n\n    async run() {\n        await this.electronApp.build(true);\n    }\n\n    async build() {\n        await this.electronApp.build();\n    }\n\n    justRun() {\n        this.electron.run();\n    }\n\n    async runPackager() {\n        this.packager = new Packager(this);\n        await this.packager.init();\n        await this.electronApp.build();\n\n        this.packager.packageApp().catch((e) => {\n            this.log.error(`while trying to build a package an error occurred: ${e}`);\n        });\n    }\n\n    async getDependency(name, version, declarationCheck = true) {\n        if (declarationCheck) {\n            try {\n                const { dependencies = {}, devDependencies = {} } = JSON.parse(\n                    fs.readFileSync(path.join(this.env.paths.meteorApp.root, 'package.json'), 'UTF-8')\n                );\n                if (!(name in dependencies) && !(name in devDependencies)) {\n                    await this.meteorApp.runNpm(['i', '-D', '-E', '--only=dev', `${name}@${version}`], 'inherit');\n                }\n            } catch (e) {\n                this.log.error(`could no read ${path.join(this.env.paths.meteorApp.root, 'package.json')}`, e);\n                process.exit(1);\n            }\n        }\n\n        const dependencyPath = path.join(this.env.paths.meteorApp.root, 'node_modules', name);\n        let dependency = null;\n        try {\n            dependency = require(dependencyPath);\n        } catch (e) {\n            if (declarationCheck) {\n                this.log.warn(`could not find ${name}, installing the default version for you: ${name}@${version}`);\n                try {\n                    await this.meteorApp.runNpm(['i', '-D', '-E', '--only=dev', `${name}@${version}`], 'inherit');\n                } catch (err) {\n                    this.log.error(err);\n                    process.exit(1);\n                }\n            } else {\n                this.log.warn(`could not find ${name}, exiting`);\n                process.exit(1);\n            }\n        } finally {\n            if (!dependency) {\n                dependency = require(dependencyPath);\n            }\n        }\n        const dependencyVersion = require(path.join(dependencyPath, 'package.json')).version;\n\n        if (dependencyVersion !== version) {\n            if (dependencyVersion.split('.')[0] !== version.split('.')[0]) {\n                this.log.warn(`you are using a ${name}@${dependencyVersion} while the recommended version is ` +\n                    `${version}, the compatibility version is different, use at your own risk, be sure to report ` +\n                    'that when submitting issues');\n            } else {\n                this.log.warn(`you are using a ${name}@${dependencyVersion} while the recommended version is ` +\n                    `${version}, be sure to report that when submitting issues`);\n            }\n        }\n        return { dependency, path: dependencyPath };\n    }\n}\n\nexport default function exports(input, output, options, { log = Logger } = { log: Logger }) {\n    return new MeteorDesktop(input, output, options, { log });\n}\n"],"mappings":"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"}
\ No newline at end of file
diff --git a/dist/log.js b/dist/log.js
new file mode 100644
index 00000000..5677ea1e
--- /dev/null
+++ b/dist/log.js
@@ -0,0 +1,75 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = void 0;
+
+/* eslint-disable no-console */
+
+/*
+ 0.OFF
+ 1.INFO
+ 2.WARN
+ 3.ERROR
+ 4.TRACE
+ 5.DEBUG
+ 6.ALL
+ */
+class Log {
+ constructor(prefix) {
+ this.prefix = prefix;
+ }
+
+ static level() {
+ return process.env.MD_LOG_LEVEL || 'ALL';
+ }
+
+ static slice(args) {
+ return Array.prototype.slice.call(args, 0);
+ }
+
+ log(type, args) {
+ console.log.apply(null, [`${type} ${this.prefix}: `].concat(Log.slice(args)));
+ }
+
+ info(...args) {
+ if (/INFO|ALL/i.test(Log.level())) {
+ this.log('INFO', args);
+ }
+ }
+
+ warn(...args) {
+ if (/WARN|ALL/i.test(Log.level())) {
+ this.log('WARN', args);
+ }
+ }
+
+ error(...args) {
+ if (/ERROR|ALL/i.test(Log.level())) {
+ this.log('ERROR', args);
+ }
+ }
+
+ debug(...args) {
+ if (/DEBUG|ALL/i.test(Log.level())) {
+ this.log('DEBUG', args);
+ }
+ }
+
+ verbose(...args) {
+ if (/VERBOSE|ALL/i.test(Log.level())) {
+ this.log('VERBOSE', args);
+ }
+ }
+
+ trace(...args) {
+ if (/TRACE|ALL/i.test(Log.level())) {
+ this.log('TRACE', args);
+ }
+ }
+
+}
+
+exports.default = Log;
+//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJMb2ciLCJjb25zdHJ1Y3RvciIsInByZWZpeCIsImxldmVsIiwicHJvY2VzcyIsImVudiIsIk1EX0xPR19MRVZFTCIsInNsaWNlIiwiYXJncyIsIkFycmF5IiwicHJvdG90eXBlIiwiY2FsbCIsImxvZyIsInR5cGUiLCJjb25zb2xlIiwiYXBwbHkiLCJjb25jYXQiLCJpbmZvIiwidGVzdCIsIndhcm4iLCJlcnJvciIsImRlYnVnIiwidmVyYm9zZSIsInRyYWNlIl0sInNvdXJjZXMiOlsiLi4vbGliL2xvZy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBuby1jb25zb2xlICovXG4vKlxuIDAuT0ZGXG4gMS5JTkZPXG4gMi5XQVJOXG4gMy5FUlJPUlxuIDQuVFJBQ0VcbiA1LkRFQlVHXG4gNi5BTExcbiAqL1xuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBMb2cge1xuICAgIGNvbnN0cnVjdG9yKHByZWZpeCkge1xuICAgICAgICB0aGlzLnByZWZpeCA9IHByZWZpeDtcbiAgICB9XG5cbiAgICBzdGF0aWMgbGV2ZWwoKSB7XG4gICAgICAgIHJldHVybiBwcm9jZXNzLmVudi5NRF9MT0dfTEVWRUwgfHwgJ0FMTCc7XG4gICAgfVxuXG4gICAgc3RhdGljIHNsaWNlKGFyZ3MpIHtcbiAgICAgICAgcmV0dXJuIEFycmF5LnByb3RvdHlwZS5zbGljZS5jYWxsKGFyZ3MsIDApO1xuICAgIH1cblxuICAgIGxvZyh0eXBlLCBhcmdzKSB7XG4gICAgICAgIGNvbnNvbGUubG9nLmFwcGx5KG51bGwsIFtgJHt0eXBlfSAgJHt0aGlzLnByZWZpeH06IGBdLmNvbmNhdChMb2cuc2xpY2UoYXJncykpKTtcbiAgICB9XG5cbiAgICBpbmZvKC4uLmFyZ3MpIHtcbiAgICAgICAgaWYgKC9JTkZPfEFMTC9pLnRlc3QoTG9nLmxldmVsKCkpKSB7XG4gICAgICAgICAgICB0aGlzLmxvZygnSU5GTycsIGFyZ3MpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgd2FybiguLi5hcmdzKSB7XG4gICAgICAgIGlmICgvV0FSTnxBTEwvaS50ZXN0KExvZy5sZXZlbCgpKSkge1xuICAgICAgICAgICAgdGhpcy5sb2coJ1dBUk4nLCBhcmdzKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIGVycm9yKC4uLmFyZ3MpIHtcbiAgICAgICAgaWYgKC9FUlJPUnxBTEwvaS50ZXN0KExvZy5sZXZlbCgpKSkge1xuICAgICAgICAgICAgdGhpcy5sb2coJ0VSUk9SJywgYXJncyk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBkZWJ1ZyguLi5hcmdzKSB7XG4gICAgICAgIGlmICgvREVCVUd8QUxML2kudGVzdChMb2cubGV2ZWwoKSkpIHtcbiAgICAgICAgICAgIHRoaXMubG9nKCdERUJVRycsIGFyZ3MpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgdmVyYm9zZSguLi5hcmdzKSB7XG4gICAgICAgIGlmICgvVkVSQk9TRXxBTEwvaS50ZXN0KExvZy5sZXZlbCgpKSkge1xuICAgICAgICAgICAgdGhpcy5sb2coJ1ZFUkJPU0UnLCBhcmdzKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHRyYWNlKC4uLmFyZ3MpIHtcbiAgICAgICAgaWYgKC9UUkFDRXxBTEwvaS50ZXN0KExvZy5sZXZlbCgpKSkge1xuICAgICAgICAgICAgdGhpcy5sb2coJ1RSQUNFJywgYXJncyk7XG4gICAgICAgIH1cbiAgICB9XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTs7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFZSxNQUFNQSxHQUFOLENBQVU7RUFDckJDLFdBQVcsQ0FBQ0MsTUFBRCxFQUFTO0lBQ2hCLEtBQUtBLE1BQUwsR0FBY0EsTUFBZDtFQUNIOztFQUVXLE9BQUxDLEtBQUssR0FBRztJQUNYLE9BQU9DLE9BQU8sQ0FBQ0MsR0FBUixDQUFZQyxZQUFaLElBQTRCLEtBQW5DO0VBQ0g7O0VBRVcsT0FBTEMsS0FBSyxDQUFDQyxJQUFELEVBQU87SUFDZixPQUFPQyxLQUFLLENBQUNDLFNBQU4sQ0FBZ0JILEtBQWhCLENBQXNCSSxJQUF0QixDQUEyQkgsSUFBM0IsRUFBaUMsQ0FBakMsQ0FBUDtFQUNIOztFQUVESSxHQUFHLENBQUNDLElBQUQsRUFBT0wsSUFBUCxFQUFhO0lBQ1pNLE9BQU8sQ0FBQ0YsR0FBUixDQUFZRyxLQUFaLENBQWtCLElBQWxCLEVBQXdCLENBQUUsR0FBRUYsSUFBSyxLQUFJLEtBQUtYLE1BQU8sSUFBekIsRUFBOEJjLE1BQTlCLENBQXFDaEIsR0FBRyxDQUFDTyxLQUFKLENBQVVDLElBQVYsQ0FBckMsQ0FBeEI7RUFDSDs7RUFFRFMsSUFBSSxDQUFDLEdBQUdULElBQUosRUFBVTtJQUNWLElBQUksWUFBWVUsSUFBWixDQUFpQmxCLEdBQUcsQ0FBQ0csS0FBSixFQUFqQixDQUFKLEVBQW1DO01BQy9CLEtBQUtTLEdBQUwsQ0FBUyxNQUFULEVBQWlCSixJQUFqQjtJQUNIO0VBQ0o7O0VBRURXLElBQUksQ0FBQyxHQUFHWCxJQUFKLEVBQVU7SUFDVixJQUFJLFlBQVlVLElBQVosQ0FBaUJsQixHQUFHLENBQUNHLEtBQUosRUFBakIsQ0FBSixFQUFtQztNQUMvQixLQUFLUyxHQUFMLENBQVMsTUFBVCxFQUFpQkosSUFBakI7SUFDSDtFQUNKOztFQUVEWSxLQUFLLENBQUMsR0FBR1osSUFBSixFQUFVO0lBQ1gsSUFBSSxhQUFhVSxJQUFiLENBQWtCbEIsR0FBRyxDQUFDRyxLQUFKLEVBQWxCLENBQUosRUFBb0M7TUFDaEMsS0FBS1MsR0FBTCxDQUFTLE9BQVQsRUFBa0JKLElBQWxCO0lBQ0g7RUFDSjs7RUFFRGEsS0FBSyxDQUFDLEdBQUdiLElBQUosRUFBVTtJQUNYLElBQUksYUFBYVUsSUFBYixDQUFrQmxCLEdBQUcsQ0FBQ0csS0FBSixFQUFsQixDQUFKLEVBQW9DO01BQ2hDLEtBQUtTLEdBQUwsQ0FBUyxPQUFULEVBQWtCSixJQUFsQjtJQUNIO0VBQ0o7O0VBRURjLE9BQU8sQ0FBQyxHQUFHZCxJQUFKLEVBQVU7SUFDYixJQUFJLGVBQWVVLElBQWYsQ0FBb0JsQixHQUFHLENBQUNHLEtBQUosRUFBcEIsQ0FBSixFQUFzQztNQUNsQyxLQUFLUyxHQUFMLENBQVMsU0FBVCxFQUFvQkosSUFBcEI7SUFDSDtFQUNKOztFQUVEZSxLQUFLLENBQUMsR0FBR2YsSUFBSixFQUFVO0lBQ1gsSUFBSSxhQUFhVSxJQUFiLENBQWtCbEIsR0FBRyxDQUFDRyxLQUFKLEVBQWxCLENBQUosRUFBb0M7TUFDaEMsS0FBS1MsR0FBTCxDQUFTLE9BQVQsRUFBa0JKLElBQWxCO0lBQ0g7RUFDSjs7QUFuRG9CIn0=
\ No newline at end of file
diff --git a/dist/meteorApp.js b/dist/meteorApp.js
new file mode 100644
index 00000000..e4508bfe
--- /dev/null
+++ b/dist/meteorApp.js
@@ -0,0 +1,923 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = void 0;
+
+var _runtime = _interopRequireDefault(require("regenerator-runtime/runtime"));
+
+var _fs = _interopRequireDefault(require("fs"));
+
+var _crossSpawn = _interopRequireDefault(require("cross-spawn"));
+
+var _semver = _interopRequireDefault(require("semver"));
+
+var _shelljs = _interopRequireDefault(require("shelljs"));
+
+var _path = _interopRequireDefault(require("path"));
+
+var _singleLineLog = _interopRequireDefault(require("single-line-log"));
+
+var _asar = _interopRequireDefault(require("@electron/asar"));
+
+var _nodeFetch = _interopRequireDefault(require("node-fetch"));
+
+var _isDesktopInjector = _interopRequireDefault(require("../skeleton/modules/autoupdate/isDesktopInjector"));
+
+var _log = _interopRequireDefault(require("./log"));
+
+var _meteorManager = _interopRequireDefault(require("./meteorManager"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+// eslint-disable-next-line no-unused-vars
+const {
+ join
+} = _path.default;
+const sll = _singleLineLog.default.stdout; // TODO: refactor all strategy ifs to one place
+
+/**
+ * Represents the Meteor app.
+ * @property {MeteorDesktop} $
+ * @class
+ */
+
+class MeteorApp {
+ /**
+ * @param {MeteorDesktop} $ - context
+ * @constructor
+ */
+ constructor($) {
+ this.log = new _log.default('meteorApp');
+ this.$ = $;
+ this.meteorManager = new _meteorManager.default($);
+ this.mobilePlatform = null;
+ this.oldManifest = null;
+ this.injector = new _isDesktopInjector.default();
+ this.matcher = new RegExp('__meteor_runtime_config__ = JSON.parse\\(decodeURIComponent\\("([^"]*)"\\)\\)');
+ this.replacer = new RegExp('(__meteor_runtime_config__ = JSON.parse\\(decodeURIComponent\\()"([^"]*)"(\\)\\))');
+ this.meteorVersion = null;
+ this.indexHTMLstrategy = null;
+ this.indexHTMLStrategies = {
+ INDEX_FROM_CORDOVA_BUILD: 1,
+ INDEX_FROM_RUNNING_SERVER: 2
+ };
+ this.deprectatedPackages = ['omega:meteor-desktop-localstorage'];
+ }
+ /**
+ * Remove any deprecated packages from meteor project.
+ * @returns {Promise}
+ */
+
+
+ async removeDeprecatedPackages() {
+ try {
+ if (this.meteorManager.checkPackages(this.deprectatedPackages)) {
+ this.log.info('deprecated meteor plugins found, removing them');
+ await this.meteorManager.deletePackages(this.deprectatedPackages);
+ }
+ } catch (e) {
+ throw new Error(e);
+ }
+ }
+ /**
+ * Ensures that required packages are added to the Meteor app.
+ */
+
+
+ async ensureDesktopHCPPackages() {
+ const desktopHCPPackages = ['communitypackages:meteor-desktop-watcher', 'communitypackages:meteor-desktop-bundler'];
+
+ if (this.$.desktop.getSettings().desktopHCP) {
+ this.log.verbose('desktopHCP is enabled, checking for required packages');
+ const packagesWithVersion = desktopHCPPackages.map(packageName => `${packageName}@${this.$.getVersion()}`);
+
+ try {
+ await this.meteorManager.ensurePackages(desktopHCPPackages, packagesWithVersion, 'desktopHCP');
+ } catch (e) {
+ throw new Error(e);
+ }
+ } else {
+ this.log.verbose('desktopHCP is not enabled, removing required packages');
+
+ try {
+ if (this.meteorManager.checkPackages(desktopHCPPackages)) {
+ await this.meteorManager.deletePackages(desktopHCPPackages);
+ }
+ } catch (e) {
+ throw new Error(e);
+ }
+ }
+ }
+ /**
+ * Adds entry to .meteor/.gitignore if necessary.
+ */
+
+
+ updateGitIgnore() {
+ this.log.verbose('updating .meteor/.gitignore'); // Lets read the .meteor/.gitignore and filter out blank lines.
+
+ const gitIgnore = _fs.default.readFileSync(this.$.env.paths.meteorApp.gitIgnore, 'UTF-8').split('\n').filter(ignoredPath => ignoredPath.trim() !== '');
+
+ if (!~gitIgnore.indexOf(this.$.env.paths.electronApp.rootName)) {
+ this.log.verbose(`adding ${this.$.env.paths.electronApp.rootName} to .meteor/.gitignore`);
+ gitIgnore.push(this.$.env.paths.electronApp.rootName);
+
+ _fs.default.writeFileSync(this.$.env.paths.meteorApp.gitIgnore, gitIgnore.join('\n'), 'UTF-8');
+ }
+ }
+ /**
+ * Reads the Meteor release version used in the app.
+ * @returns {string}
+ */
+
+
+ getMeteorRelease() {
+ let release = _fs.default.readFileSync(this.$.env.paths.meteorApp.release, 'UTF-8').replace(/\r/gm, '').split('\n')[0];
+
+ [, release] = release.split('@'); // We do not care if it is beta.
+
+ if (~release.indexOf('-')) {
+ [release] = release.split('-');
+ }
+
+ return release;
+ }
+ /**
+ * Cast Meteor release to semver version.
+ * @returns {string}
+ */
+
+
+ castMeteorReleaseToSemver() {
+ return `${this.getMeteorRelease()}.0.0`.match(/(^\d+\.\d+\.\d+)/gmi)[0];
+ }
+ /**
+ * Validate meteor version against a versionRange.
+ * @param {string} versionRange - semver version range
+ */
+
+
+ checkMeteorVersion(versionRange) {
+ const release = this.castMeteorReleaseToSemver();
+
+ if (!_semver.default.satisfies(release, versionRange)) {
+ if (this.$.env.options.skipMobileBuild) {
+ this.log.error(`wrong meteor version (${release}) in project - only ` + `${versionRange} is supported`);
+ } else {
+ this.log.error(`wrong meteor version (${release}) in project - only ` + `${versionRange} is supported for automatic meteor builds (you can always ` + 'try with `--skip-mobile-build` if you are using meteor >= 1.2.1');
+ }
+
+ process.exit(1);
+ }
+ }
+ /**
+ * Decides which strategy to use while trying to get client build out of Meteor project.
+ * @returns {number}
+ */
+
+
+ chooseStrategy() {
+ if (this.$.env.options.forceCordovaBuild) {
+ return this.indexHTMLStrategies.INDEX_FROM_CORDOVA_BUILD;
+ }
+
+ const release = this.castMeteorReleaseToSemver();
+
+ if (_semver.default.satisfies(release, '> 1.3.4')) {
+ return this.indexHTMLStrategies.INDEX_FROM_RUNNING_SERVER;
+ }
+
+ if (_semver.default.satisfies(release, '1.3.4')) {
+ const explodedVersion = this.getMeteorRelease().split('.');
+
+ if (explodedVersion.length >= 4) {
+ if (explodedVersion[3] > 1) {
+ return this.indexHTMLStrategies.INDEX_FROM_RUNNING_SERVER;
+ }
+
+ return this.indexHTMLStrategies.INDEX_FROM_CORDOVA_BUILD;
+ }
+ }
+
+ return this.indexHTMLStrategies.INDEX_FROM_CORDOVA_BUILD;
+ }
+ /**
+ * Checks required preconditions.
+ * - Meteor version
+ * - is mobile platform added
+ */
+
+
+ async checkPreconditions() {
+ if (this.$.env.options.skipMobileBuild) {
+ this.checkMeteorVersion('>= 1.2.1');
+ } else {
+ this.checkMeteorVersion('>= 1.3.3');
+ this.indexHTMLstrategy = this.chooseStrategy();
+
+ if (this.indexHTMLstrategy === this.indexHTMLStrategies.INDEX_FROM_CORDOVA_BUILD) {
+ this.log.debug('meteor version is < 1.3.4.2 so the index.html from cordova-build will' + ' be used');
+ } else {
+ this.log.debug('meteor version is >= 1.3.4.2 so the index.html will be downloaded ' + 'from __cordova/index.html');
+ }
+ }
+
+ if (!this.$.env.options.skipMobileBuild) {
+ const platforms = _fs.default.readFileSync(this.$.env.paths.meteorApp.platforms, 'UTF-8');
+
+ if (!~platforms.indexOf('android') && !~platforms.indexOf('ios')) {
+ if (!this.$.env.options.android) {
+ this.mobilePlatform = 'ios';
+ } else {
+ this.mobilePlatform = 'android';
+ }
+
+ this.log.warn(`no mobile target detected - will add '${this.mobilePlatform}' ` + 'just to get a mobile build');
+
+ try {
+ await this.addMobilePlatform(this.mobilePlatform);
+ } catch (e) {
+ this.log.error('failed to add a mobile platform - please try to do it manually');
+ process.exit(1);
+ }
+ }
+ }
+ }
+ /**
+ * Tries to add a mobile platform to meteor project.
+ * @param {string} platform - platform to add
+ * @returns {Promise}
+ */
+
+
+ addMobilePlatform(platform) {
+ return new Promise((resolve, reject) => {
+ this.log.verbose(`adding mobile platform: ${platform}`);
+ (0, _crossSpawn.default)('meteor', ['add-platform', platform], {
+ cwd: this.$.env.paths.meteorApp.root,
+ stdio: this.$.env.stdio
+ }).on('exit', () => {
+ const platforms = _fs.default.readFileSync(this.$.env.paths.meteorApp.platforms, 'UTF-8');
+
+ if (!~platforms.indexOf('android') && !~platforms.indexOf('ios')) {
+ reject();
+ } else {
+ resolve();
+ }
+ });
+ });
+ }
+ /**
+ * Tries to remove a mobile platform from meteor project.
+ * @param {string} platform - platform to remove
+ * @returns {Promise}
+ */
+
+
+ removeMobilePlatform(platform) {
+ if (this.$.env.options.skipRemoveMobilePlatform) {
+ return Promise.resolve();
+ }
+
+ return new Promise((resolve, reject) => {
+ this.log.verbose(`removing mobile platform: ${platform}`);
+ (0, _crossSpawn.default)('meteor', ['remove-platform', platform], {
+ cwd: this.$.env.paths.meteorApp.root,
+ stdio: this.$.env.stdio,
+ env: Object.assign({
+ METEOR_PRETTY_OUTPUT: 0
+ }, process.env)
+ }).on('exit', () => {
+ const platforms = _fs.default.readFileSync(this.$.env.paths.meteorApp.platforms, 'UTF-8');
+
+ if (~platforms.indexOf(platform)) {
+ reject();
+ } else {
+ resolve();
+ }
+ });
+ });
+ }
+ /**
+ * Just checks for index.html and program.json existence.
+ * @returns {boolean}
+ */
+
+
+ isCordovaBuildReady() {
+ if (this.indexHTMLstrategy === this.indexHTMLStrategies.INDEX_FROM_CORDOVA_BUILD) {
+ return this.$.utils.exists(this.$.env.paths.meteorApp.cordovaBuildIndex) && this.$.utils.exists(this.$.env.paths.meteorApp.cordovaBuildProgramJson) && (!this.oldManifest || this.oldManifest && this.oldManifest !== _fs.default.readFileSync(this.$.env.paths.meteorApp.cordovaBuildProgramJson, 'UTF-8'));
+ }
+
+ return this.$.utils.exists(this.$.env.paths.meteorApp.webCordovaProgramJson) && (!this.oldManifest || this.oldManifest && this.oldManifest !== _fs.default.readFileSync(this.$.env.paths.meteorApp.webCordovaProgramJson, 'UTF-8'));
+ }
+ /**
+ * Fetches index.html from running project.
+ * @returns {Promise.<*>}
+ */
+
+
+ async acquireIndex() {
+ const port = this.$.env.options.port ? this.$.env.options.port : 3080;
+ this.log.info('acquiring index.html');
+ const res = await (0, _nodeFetch.default)(`http://127.0.0.1:${port}/__cordova/index.html`);
+ const text = await res.text(); // Simple test if we really download index.html for web.cordova.
+
+ if (~text.indexOf('src="/cordova.js"')) {
+ return text;
+ }
+
+ return false;
+ }
+ /**
+ * Fetches mainfest.json from running project.
+ * @returns {Promise.}
+ */
+
+
+ async acquireManifest() {
+ const port = this.$.env.options.port ? this.$.env.options.port : 3080;
+ this.log.info('acquiring manifest.json');
+ const res = await (0, _nodeFetch.default)(`http://127.0.0.1:${port}/__cordova/manifest.json?meteor_dont_serve_index=true`);
+ const text = await res.text();
+ return JSON.parse(text);
+ }
+ /**
+ * Tries to get a mobile build from meteor app.
+ * In case of failure leaves a meteor.log.
+ * A lot of stuff is happening here - but the main aim is to get a mobile build from
+ * .meteor/local/cordova-build/www/application and exit as soon as possible.
+ *
+ * @returns {Promise}
+ */
+
+
+ buildMobileTarget() {
+ const programJson = this.indexHTMLstrategy === this.indexHTMLStrategies.INDEX_FROM_CORDOVA_BUILD ? this.$.env.paths.meteorApp.cordovaBuildProgramJson : this.$.env.paths.meteorApp.webCordovaProgramJson;
+
+ if (this.$.utils.exists(programJson)) {
+ this.oldManifest = _fs.default.readFileSync(programJson, 'UTF-8');
+ }
+
+ return new Promise((resolve, reject) => {
+ const self = this;
+ let log = '';
+ let desiredExit = false;
+ let buildTimeout = null;
+ let errorTimeout = null;
+ let messageTimeout = null;
+ let killTimeout = null;
+ let cordovaCheckInterval = null;
+ let portProblem = false;
+
+ function windowsKill(pid) {
+ self.log.debug(`killing pid: ${pid}`);
+
+ _crossSpawn.default.sync('taskkill', ['/pid', pid, '/f', '/t']); // We will look for other process which might have been created outside the
+ // process tree.
+ // Lets list all node.exe processes.
+
+
+ const out = _crossSpawn.default.sync('wmic', ['process', 'where', 'caption="node.exe"', 'get', 'commandline,processid']).stdout.toString('utf-8').split('\n');
+
+ const args = self.prepareArguments(); // Lets mount regex.
+
+ const regexV1 = new RegExp(`${args.join('\\s+')}\\s+(\\d+)`, 'gm');
+ const regexV2 = new RegExp(`"${args.join('"\\s+"')}"\\s+(\\d+)`, 'gm'); // No we will check for those with the matching params.
+
+ out.forEach(line => {
+ const match = regexV1.exec(line) || regexV2.exec(line) || false;
+
+ if (match) {
+ self.log.debug(`killing pid: ${match[1]}`);
+
+ _crossSpawn.default.sync('taskkill', ['/pid', match[1], '/f', '/t']);
+ }
+
+ regexV1.lastIndex = 0;
+ regexV2.lastIndex = 0;
+ });
+ }
+
+ function writeLog() {
+ _fs.default.writeFileSync('meteor.log', log, 'UTF-8');
+ }
+
+ function clearTimeoutsAndIntervals() {
+ clearInterval(cordovaCheckInterval);
+ clearTimeout(buildTimeout);
+ clearTimeout(errorTimeout);
+ clearTimeout(messageTimeout);
+ clearTimeout(killTimeout);
+ }
+
+ const args = this.prepareArguments();
+ this.log.info(`running "meteor ${args.join(' ')}"... this might take a while`);
+ const env = {
+ METEOR_PRETTY_OUTPUT: 0,
+ METEOR_NO_RELEASE_CHECK: 1
+ };
+
+ if (this.$.env.options.prodDebug) {
+ env.METEOR_DESKOP_PROD_DEBUG = true;
+ } // Lets spawn meteor.
+
+
+ const child = (0, _crossSpawn.default)('meteor', args, {
+ env: Object.assign(env, process.env),
+ cwd: this.$.env.paths.meteorApp.root
+ }, {
+ shell: true
+ }); // Kills the currently running meteor command.
+
+ function kill() {
+ sll('');
+ child.kill('SIGKILL');
+
+ if (self.$.env.os.isWindows) {
+ windowsKill(child.pid);
+ }
+ }
+
+ function exit() {
+ killTimeout = setTimeout(() => {
+ clearTimeoutsAndIntervals();
+ desiredExit = true;
+ kill();
+ resolve();
+ }, 500);
+ }
+
+ function copyBuild() {
+ self.copyBuild().then(() => {
+ exit();
+ }).catch(() => {
+ clearTimeoutsAndIntervals();
+ kill();
+ writeLog();
+ reject('copy');
+ });
+ }
+
+ cordovaCheckInterval = setInterval(() => {
+ // Check if we already have cordova-build ready.
+ if (this.isCordovaBuildReady()) {
+ // If so, then exit immediately.
+ if (this.indexHTMLstrategy === this.indexHTMLStrategies.INDEX_FROM_CORDOVA_BUILD) {
+ copyBuild();
+ }
+ }
+ }, 1000);
+ child.stderr.on('data', chunk => {
+ const line = chunk.toString('UTF-8');
+ log += `${line}\n`;
+
+ if (errorTimeout) {
+ clearTimeout(errorTimeout);
+ } // Do not exit if this is the warning for using --production.
+ // Output exceeds -> https://github.com/meteor/meteor/issues/8592
+
+
+ if (!~line.indexOf('--production') && !~line.indexOf('Output exceeds ') && !~line.indexOf('Node#moveTo') && !~line.indexOf('Browserslist') && Array.isArray(self.$.env.options.ignoreStderr) && self.$.env.options.ignoreStderr.every(str => !~line.indexOf(str))) {
+ self.log.warn('STDERR:', line); // We will exit 1s after last error in stderr.
+
+ errorTimeout = setTimeout(() => {
+ clearTimeoutsAndIntervals();
+ kill();
+ writeLog();
+ reject('error');
+ }, 1000);
+ }
+ });
+ child.stdout.on('data', chunk => {
+ const line = chunk.toString('UTF-8');
+
+ if (!desiredExit && line.trim().replace(/[\n\r\t\v\f]+/gm, '') !== '') {
+ const linesToDisplay = line.trim().split('\n\r'); // Only display last line from the chunk.
+
+ const sanitizedLine = linesToDisplay.pop().replace(/[\n\r\t\v\f]+/gm, '');
+ sll(sanitizedLine);
+ }
+
+ log += `${line}\n`;
+
+ if (~line.indexOf('after_platform_add')) {
+ sll('');
+ this.log.info('done... 10%');
+ }
+
+ if (~line.indexOf('Local package version')) {
+ if (messageTimeout) {
+ clearTimeout(messageTimeout);
+ }
+
+ messageTimeout = setTimeout(() => {
+ sll('');
+ this.log.info('building in progress...');
+ }, 1500);
+ }
+
+ if (~line.indexOf('Preparing Cordova project')) {
+ sll('');
+ this.log.info('done... 60%');
+ }
+
+ if (~line.indexOf('Can\'t listen on port')) {
+ portProblem = true;
+ }
+
+ if (~line.indexOf('Your application has errors')) {
+ if (errorTimeout) {
+ clearTimeout(errorTimeout);
+ }
+
+ errorTimeout = setTimeout(() => {
+ clearTimeoutsAndIntervals();
+ kill();
+ writeLog();
+ reject('errorInApp');
+ }, 1000);
+ }
+
+ if (~line.indexOf('App running at')) {
+ copyBuild();
+ }
+ }); // When Meteor exits
+
+ child.on('exit', () => {
+ sll('');
+ clearTimeoutsAndIntervals();
+
+ if (!desiredExit) {
+ writeLog();
+
+ if (portProblem) {
+ reject('port');
+ } else {
+ reject('exit');
+ }
+ }
+ });
+ buildTimeout = setTimeout(() => {
+ kill();
+ writeLog();
+ reject('timeout');
+ }, this.$.env.options.buildTimeout ? this.$.env.options.buildTimeout * 1000 : 600000);
+ });
+ }
+ /**
+ * Replaces the DDP url that was used originally when Meteor was building the client.
+ * @param {string} indexHtml - path to index.html from the client
+ */
+
+
+ updateDdpUrl(indexHtml) {
+ let content;
+ let runtimeConfig;
+
+ try {
+ content = _fs.default.readFileSync(indexHtml, 'UTF-8');
+ } catch (e) {
+ this.log.error(`error loading index.html file: ${e.message}`);
+ process.exit(1);
+ }
+
+ if (!this.matcher.test(content)) {
+ this.log.error('could not find runtime config in index file');
+ process.exit(1);
+ }
+
+ try {
+ const matches = content.match(this.matcher);
+ runtimeConfig = JSON.parse(decodeURIComponent(matches[1]));
+ } catch (e) {
+ this.log.error('could not find runtime config in index file');
+ process.exit(1);
+ }
+
+ if (this.$.env.options.ddpUrl.substr(-1, 1) !== '/') {
+ this.$.env.options.ddpUrl += '/';
+ }
+
+ runtimeConfig.ROOT_URL = this.$.env.options.ddpUrl;
+ runtimeConfig.DDP_DEFAULT_CONNECTION_URL = this.$.env.options.ddpUrl;
+ content = content.replace(this.replacer, `$1"${encodeURIComponent(JSON.stringify(runtimeConfig))}"$3`);
+
+ try {
+ _fs.default.writeFileSync(indexHtml, content);
+ } catch (e) {
+ this.log.error(`error writing index.html file: ${e.message}`);
+ process.exit(1);
+ }
+
+ this.log.info('successfully updated ddp string in the runtime config of a mobile build' + ` to ${this.$.env.options.ddpUrl}`);
+ }
+ /**
+ * Prepares the arguments passed to `meteor` command.
+ * @returns {string[]}
+ */
+
+
+ prepareArguments() {
+ const args = ['run', '--verbose', `--mobile-server=${this.$.env.options.ddpUrl}`];
+
+ if (this.$.env.isProductionBuild()) {
+ args.push('--production');
+ }
+
+ args.push('-p');
+
+ if (this.$.env.options.port) {
+ args.push(this.$.env.options.port);
+ } else {
+ args.push('3080');
+ }
+
+ if (this.$.env.options.meteorSettings) {
+ args.push('--settings', this.$.env.options.meteorSettings);
+ }
+
+ return args;
+ }
+ /**
+ * Validates the mobile build and copies it into electron app.
+ */
+
+
+ async copyBuild() {
+ this.log.debug('clearing build dir');
+
+ try {
+ await this.$.utils.rmWithRetries('-rf', this.$.env.paths.electronApp.meteorApp);
+ } catch (e) {
+ throw new Error(e);
+ }
+
+ let prefix = 'cordovaBuild';
+ let copyPathPostfix = '';
+
+ if (this.indexHTMLstrategy === this.indexHTMLStrategies.INDEX_FROM_RUNNING_SERVER) {
+ prefix = 'webCordova';
+ copyPathPostfix = `${_path.default.sep}*`;
+ let indexHtml;
+
+ try {
+ _fs.default.mkdirSync(this.$.env.paths.electronApp.meteorApp);
+
+ indexHtml = await this.acquireIndex();
+
+ _fs.default.writeFileSync(this.$.env.paths.electronApp.meteorAppIndex, indexHtml);
+
+ this.log.info('successfully downloaded index.html from running meteor app');
+ } catch (e) {
+ this.log.error('error while trying to download index.html for web.cordova, ' + 'be sure that you are running a mobile target or with' + ' --mobile-server: ', e);
+ throw e;
+ }
+ }
+
+ const cordovaBuild = this.$.env.paths.meteorApp[prefix];
+ const {
+ cordovaBuildIndex
+ } = this.$.env.paths.meteorApp;
+ const cordovaBuildProgramJson = this.$.env.paths.meteorApp[`${prefix}ProgramJson`];
+
+ if (!this.$.utils.exists(cordovaBuild)) {
+ this.log.error(`no mobile build found at ${cordovaBuild}`);
+ this.log.error('are you sure you did run meteor with --mobile-server?');
+ throw new Error('required file not present');
+ }
+
+ if (!this.$.utils.exists(cordovaBuildProgramJson)) {
+ this.log.error('no program.json found in mobile build found at ' + `${cordovaBuild}`);
+ this.log.error('are you sure you did run meteor with --mobile-server?');
+ throw new Error('required file not present');
+ }
+
+ if (this.indexHTMLstrategy !== this.indexHTMLStrategies.INDEX_FROM_RUNNING_SERVER) {
+ if (!this.$.utils.exists(cordovaBuildIndex)) {
+ this.log.error('no index.html found in cordova build found at ' + `${cordovaBuild}`);
+ this.log.error('are you sure you did run meteor with --mobile-server?');
+ throw new Error('required file not present');
+ }
+ }
+
+ this.log.verbose('copying mobile build');
+
+ _shelljs.default.cp('-R', `${cordovaBuild}${copyPathPostfix}`, this.$.env.paths.electronApp.meteorApp); // Because of various permission problems here we try to clear te path by clearing
+ // all possible restrictions.
+
+
+ _shelljs.default.chmod('-R', '777', this.$.env.paths.electronApp.meteorApp);
+
+ if (this.$.env.os.isWindows) {
+ _shelljs.default.exec(`attrib -r ${this.$.env.paths.electronApp.meteorApp}${_path.default.sep}*.* /s`);
+ }
+
+ if (this.indexHTMLstrategy === this.indexHTMLStrategies.INDEX_FROM_RUNNING_SERVER) {
+ let programJson;
+
+ try {
+ programJson = await this.acquireManifest();
+
+ _fs.default.writeFileSync(this.$.env.paths.electronApp.meteorAppProgramJson, JSON.stringify(programJson, null, 4));
+
+ this.log.info('successfully downloaded manifest.json from running meteor app');
+ } catch (e) {
+ this.log.error('error while trying to download manifest.json for web.cordova,' + ' be sure that you are running a mobile target or with' + ' --mobile-server: ', e);
+ throw e;
+ }
+ }
+
+ this.log.info('mobile build copied to electron app');
+ this.log.debug('copy cordova.js to meteor build');
+
+ _shelljs.default.cp(join(__dirname, '..', 'skeleton', 'cordova.js'), this.$.env.paths.electronApp.meteorApp);
+ }
+ /**
+ * Injects Meteor.isDesktop
+ */
+
+
+ injectIsDesktop() {
+ this.log.info('injecting isDesktop');
+ let manifestJsonPath = this.$.env.paths.meteorApp.cordovaBuildProgramJson;
+
+ if (this.indexHTMLstrategy === this.indexHTMLStrategies.INDEX_FROM_RUNNING_SERVER) {
+ manifestJsonPath = this.$.env.paths.meteorApp.webCordovaProgramJson;
+ }
+
+ try {
+ const {
+ manifest
+ } = JSON.parse(_fs.default.readFileSync(manifestJsonPath, 'UTF-8'));
+ let injected = false;
+ let injectedStartupDidComplete = false;
+ let result = null; // We will search in every .js file in the manifest.
+ // We could probably detect whether this is a dev or production build and only search in
+ // the correct files, but for now this should be fine.
+
+ manifest.forEach(file => {
+ let fileContents; // Hacky way of setting isDesktop.
+
+ if (file.type === 'js') {
+ fileContents = _fs.default.readFileSync(join(this.$.env.paths.electronApp.meteorApp, file.path), 'UTF-8');
+ result = this.injector.processFileContents(fileContents);
+ ({
+ fileContents
+ } = result);
+ injectedStartupDidComplete = result.injectedStartupDidComplete ? true : injectedStartupDidComplete;
+ injected = result.injected ? true : injected;
+
+ _fs.default.writeFileSync(join(this.$.env.paths.electronApp.meteorApp, file.path), fileContents);
+ }
+ });
+
+ if (!injected) {
+ this.log.error('error injecting isDesktop global var.');
+ process.exit(1);
+ }
+
+ if (!injectedStartupDidComplete) {
+ this.log.error('error injecting isDesktop for startupDidComplete');
+ process.exit(1);
+ }
+ } catch (e) {
+ this.log.error('error occurred while injecting isDesktop: ', e);
+ process.exit(1);
+ }
+
+ this.log.info('injected successfully');
+ }
+ /**
+ * Builds, modifies and copies the meteor app to electron app.
+ */
+
+
+ async build() {
+ this.log.info('checking for any mobile platform');
+
+ try {
+ await this.checkPreconditions();
+ } catch (e) {
+ this.log.error('error occurred during checking preconditions: ', e);
+ process.exit(1);
+ }
+
+ this.log.info('building meteor app');
+
+ if (!this.$.env.options.skipMobileBuild) {
+ try {
+ await this.buildMobileTarget();
+ } catch (reason) {
+ switch (reason) {
+ case 'timeout':
+ this.log.error('timeout while building, log has been written to meteor.log');
+ break;
+
+ case 'error':
+ this.log.error('build was terminated by meteor-desktop as some errors were reported to stderr, you ' + 'should see it above, also check meteor.log for more info, to ignore it use the ' + '--ignore-stderr ""');
+ break;
+
+ case 'errorInApp':
+ this.log.error('your meteor app has errors - look into meteor.log for more' + ' info');
+ break;
+
+ case 'port':
+ this.log.error('your port 3080 is currently used (you probably have this or other ' + 'meteor project running?), use `-t` or `--meteor-port` to use ' + 'different port while building');
+ break;
+
+ case 'exit':
+ this.log.error('meteor cmd exited unexpectedly, log has been written to meteor.log');
+ break;
+
+ case 'copy':
+ this.log.error('error encountered when copying the build');
+ break;
+
+ default:
+ this.log.error('error occurred during building mobile target', reason);
+ }
+
+ if (this.mobilePlatform) {
+ await this.removeMobilePlatform(this.mobilePlatform);
+ }
+
+ process.exit(1);
+ }
+ } else {
+ this.indexHTMLstrategy = this.chooseStrategy();
+
+ try {
+ await this.copyBuild();
+ } catch (e) {
+ process.exit(1);
+ }
+ }
+
+ this.injectIsDesktop();
+ this.changeDdpUrl();
+
+ try {
+ await this.packToAsar();
+ } catch (e) {
+ this.log.error('error while packing meteor app to asar');
+ process.exit(1);
+ }
+
+ this.log.info('meteor build finished');
+
+ if (this.mobilePlatform) {
+ await this.removeMobilePlatform(this.mobilePlatform);
+ }
+ }
+
+ changeDdpUrl() {
+ if (this.$.env.options.ddpUrl !== null) {
+ try {
+ this.updateDdpUrl(this.$.env.paths.electronApp.meteorAppIndex);
+ } catch (e) {
+ this.log.error(`error while trying to change the ddp url: ${e.message}`);
+ }
+ }
+ }
+
+ packToAsar() {
+ this.log.info('packing meteor app to asar archive');
+ return new Promise((resolve, reject) => _asar.default.createPackage(this.$.env.paths.electronApp.meteorApp, _path.default.join(this.$.env.paths.electronApp.root, 'meteor.asar')).then(() => {
+ // On Windows some files might still be blocked. Giving a tick for them to be
+ // ready for deletion.
+ setImmediate(() => {
+ this.log.verbose('clearing meteor app after packing');
+ this.$.utils.rmWithRetries('-rf', this.$.env.paths.electronApp.meteorApp).then(() => {
+ resolve();
+ }).catch(e => {
+ reject(e);
+ });
+ });
+ }));
+ }
+ /**
+ * Wrapper for spawning npm.
+ * @param {Array} commands - commands for spawn
+ * @param {string} stdio
+ * @param {string} cwd
+ * @return {Promise}
+ */
+
+
+ runNpm(commands, stdio = 'ignore', cwd = this.$.env.paths.meteorApp.root) {
+ return new Promise((resolve, reject) => {
+ this.log.verbose(`executing meteor npm ${commands.join(' ')}`);
+ (0, _crossSpawn.default)('meteor', ['npm', ...commands], {
+ cwd,
+ stdio
+ }).on('exit', code => code === 0 ? resolve() : reject(new Error(`npm exit code was ${code}`)));
+ });
+ }
+
+}
+
+exports.default = MeteorApp;
+//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["join","path","sll","singleLineLog","stdout","MeteorApp","constructor","$","log","Log","meteorManager","MeteorManager","mobilePlatform","oldManifest","injector","IsDesktopInjector","matcher","RegExp","replacer","meteorVersion","indexHTMLstrategy","indexHTMLStrategies","INDEX_FROM_CORDOVA_BUILD","INDEX_FROM_RUNNING_SERVER","deprectatedPackages","removeDeprecatedPackages","checkPackages","info","deletePackages","e","Error","ensureDesktopHCPPackages","desktopHCPPackages","desktop","getSettings","desktopHCP","verbose","packagesWithVersion","map","packageName","getVersion","ensurePackages","updateGitIgnore","gitIgnore","fs","readFileSync","env","paths","meteorApp","split","filter","ignoredPath","trim","indexOf","electronApp","rootName","push","writeFileSync","getMeteorRelease","release","replace","castMeteorReleaseToSemver","match","checkMeteorVersion","versionRange","semver","satisfies","options","skipMobileBuild","error","process","exit","chooseStrategy","forceCordovaBuild","explodedVersion","length","checkPreconditions","debug","platforms","android","warn","addMobilePlatform","platform","Promise","resolve","reject","spawn","cwd","root","stdio","on","removeMobilePlatform","skipRemoveMobilePlatform","Object","assign","METEOR_PRETTY_OUTPUT","isCordovaBuildReady","utils","exists","cordovaBuildIndex","cordovaBuildProgramJson","webCordovaProgramJson","acquireIndex","port","res","fetch","text","acquireManifest","JSON","parse","buildMobileTarget","programJson","self","desiredExit","buildTimeout","errorTimeout","messageTimeout","killTimeout","cordovaCheckInterval","portProblem","windowsKill","pid","sync","out","toString","args","prepareArguments","regexV1","regexV2","forEach","line","exec","lastIndex","writeLog","clearTimeoutsAndIntervals","clearInterval","clearTimeout","METEOR_NO_RELEASE_CHECK","prodDebug","METEOR_DESKOP_PROD_DEBUG","child","shell","kill","os","isWindows","setTimeout","copyBuild","then","catch","setInterval","stderr","chunk","Array","isArray","ignoreStderr","every","str","linesToDisplay","sanitizedLine","pop","updateDdpUrl","indexHtml","content","runtimeConfig","message","test","matches","decodeURIComponent","ddpUrl","substr","ROOT_URL","DDP_DEFAULT_CONNECTION_URL","encodeURIComponent","stringify","isProductionBuild","meteorSettings","rmWithRetries","prefix","copyPathPostfix","sep","mkdirSync","meteorAppIndex","cordovaBuild","cp","chmod","meteorAppProgramJson","__dirname","injectIsDesktop","manifestJsonPath","manifest","injected","injectedStartupDidComplete","result","file","fileContents","type","processFileContents","build","reason","changeDdpUrl","packToAsar","asar","createPackage","setImmediate","runNpm","commands","code"],"sources":["../lib/meteorApp.js"],"sourcesContent":["// eslint-disable-next-line no-unused-vars\nimport regeneratorRuntime from 'regenerator-runtime/runtime';\nimport fs from 'fs';\nimport spawn from 'cross-spawn';\nimport semver from 'semver';\nimport shell from 'shelljs';\nimport path from 'path';\nimport singleLineLog from 'single-line-log';\nimport asar from '@electron/asar';\nimport fetch from 'node-fetch';\n\nimport IsDesktopInjector from '../skeleton/modules/autoupdate/isDesktopInjector';\nimport Log from './log';\nimport MeteorManager from './meteorManager';\n\nconst { join } = path;\nconst sll = singleLineLog.stdout;\n\n// TODO: refactor all strategy ifs to one place\n\n/**\n * Represents the Meteor app.\n * @property {MeteorDesktop} $\n * @class\n */\nexport default class MeteorApp {\n    /**\n     * @param {MeteorDesktop} $ - context\n     * @constructor\n     */\n    constructor($) {\n        this.log = new Log('meteorApp');\n        this.$ = $;\n        this.meteorManager = new MeteorManager($);\n        this.mobilePlatform = null;\n        this.oldManifest = null;\n        this.injector = new IsDesktopInjector();\n        this.matcher = new RegExp(\n            '__meteor_runtime_config__ = JSON.parse\\\\(decodeURIComponent\\\\(\"([^\"]*)\"\\\\)\\\\)'\n        );\n        this.replacer = new RegExp(\n            '(__meteor_runtime_config__ = JSON.parse\\\\(decodeURIComponent\\\\()\"([^\"]*)\"(\\\\)\\\\))'\n        );\n        this.meteorVersion = null;\n        this.indexHTMLstrategy = null;\n\n        this.indexHTMLStrategies = {\n            INDEX_FROM_CORDOVA_BUILD: 1,\n            INDEX_FROM_RUNNING_SERVER: 2\n        };\n\n        this.deprectatedPackages = ['omega:meteor-desktop-localstorage'];\n    }\n\n    /**\n     * Remove any deprecated packages from meteor project.\n     * @returns {Promise<void>}\n     */\n    async removeDeprecatedPackages() {\n        try {\n            if (this.meteorManager.checkPackages(this.deprectatedPackages)) {\n                this.log.info('deprecated meteor plugins found, removing them');\n                await this.meteorManager.deletePackages(this.deprectatedPackages);\n            }\n        } catch (e) {\n            throw new Error(e);\n        }\n    }\n\n    /**\n     * Ensures that required packages are added to the Meteor app.\n     */\n    async ensureDesktopHCPPackages() {\n        const desktopHCPPackages = ['communitypackages:meteor-desktop-watcher', 'communitypackages:meteor-desktop-bundler'];\n        if (this.$.desktop.getSettings().desktopHCP) {\n            this.log.verbose('desktopHCP is enabled, checking for required packages');\n\n            const packagesWithVersion = desktopHCPPackages.map(packageName => `${packageName}@${this.$.getVersion()}`);\n\n            try {\n                await this.meteorManager.ensurePackages(desktopHCPPackages, packagesWithVersion, 'desktopHCP');\n            } catch (e) {\n                throw new Error(e);\n            }\n        } else {\n            this.log.verbose('desktopHCP is not enabled, removing required packages');\n\n            try {\n                if (this.meteorManager.checkPackages(desktopHCPPackages)) {\n                    await this.meteorManager.deletePackages(desktopHCPPackages);\n                }\n            } catch (e) {\n                throw new Error(e);\n            }\n        }\n    }\n\n    /**\n     * Adds entry to .meteor/.gitignore if necessary.\n     */\n    updateGitIgnore() {\n        this.log.verbose('updating .meteor/.gitignore');\n        // Lets read the .meteor/.gitignore and filter out blank lines.\n        const gitIgnore = fs.readFileSync(this.$.env.paths.meteorApp.gitIgnore, 'UTF-8')\n            .split('\\n').filter(ignoredPath => ignoredPath.trim() !== '');\n\n        if (!~gitIgnore.indexOf(this.$.env.paths.electronApp.rootName)) {\n            this.log.verbose(`adding ${this.$.env.paths.electronApp.rootName} to .meteor/.gitignore`);\n            gitIgnore.push(this.$.env.paths.electronApp.rootName);\n\n            fs.writeFileSync(this.$.env.paths.meteorApp.gitIgnore, gitIgnore.join('\\n'), 'UTF-8');\n        }\n    }\n\n    /**\n     * Reads the Meteor release version used in the app.\n     * @returns {string}\n     */\n    getMeteorRelease() {\n        let release = fs.readFileSync(this.$.env.paths.meteorApp.release, 'UTF-8')\n            .replace(/\\r/gm, '')\n            .split('\\n')[0];\n        ([, release] = release.split('@'));\n        // We do not care if it is beta.\n        if (~release.indexOf('-')) {\n            ([release] = release.split('-'));\n        }\n        return release;\n    }\n\n    /**\n     * Cast Meteor release to semver version.\n     * @returns {string}\n     */\n    castMeteorReleaseToSemver() {\n        return `${this.getMeteorRelease()}.0.0`.match(/(^\\d+\\.\\d+\\.\\d+)/gmi)[0];\n    }\n\n    /**\n     * Validate meteor version against a versionRange.\n     * @param {string} versionRange - semver version range\n     */\n    checkMeteorVersion(versionRange) {\n        const release = this.castMeteorReleaseToSemver();\n        if (!semver.satisfies(release, versionRange)) {\n            if (this.$.env.options.skipMobileBuild) {\n                this.log.error(`wrong meteor version (${release}) in project - only ` +\n                    `${versionRange} is supported`);\n            } else {\n                this.log.error(`wrong meteor version (${release}) in project - only ` +\n                    `${versionRange} is supported for automatic meteor builds (you can always ` +\n                    'try with `--skip-mobile-build` if you are using meteor >= 1.2.1');\n            }\n            process.exit(1);\n        }\n    }\n\n    /**\n     * Decides which strategy to use while trying to get client build out of Meteor project.\n     * @returns {number}\n     */\n    chooseStrategy() {\n        if (this.$.env.options.forceCordovaBuild) {\n            return this.indexHTMLStrategies.INDEX_FROM_CORDOVA_BUILD;\n        }\n\n        const release = this.castMeteorReleaseToSemver();\n        if (semver.satisfies(release, '> 1.3.4')) {\n            return this.indexHTMLStrategies.INDEX_FROM_RUNNING_SERVER;\n        }\n        if (semver.satisfies(release, '1.3.4')) {\n            const explodedVersion = this.getMeteorRelease().split('.');\n            if (explodedVersion.length >= 4) {\n                if (explodedVersion[3] > 1) {\n                    return this.indexHTMLStrategies.INDEX_FROM_RUNNING_SERVER;\n                }\n                return this.indexHTMLStrategies.INDEX_FROM_CORDOVA_BUILD;\n            }\n        }\n        return this.indexHTMLStrategies.INDEX_FROM_CORDOVA_BUILD;\n    }\n\n    /**\n     * Checks required preconditions.\n     * - Meteor version\n     * - is mobile platform added\n     */\n    async checkPreconditions() {\n        if (this.$.env.options.skipMobileBuild) {\n            this.checkMeteorVersion('>= 1.2.1');\n        } else {\n            this.checkMeteorVersion('>= 1.3.3');\n            this.indexHTMLstrategy = this.chooseStrategy();\n            if (this.indexHTMLstrategy === this.indexHTMLStrategies.INDEX_FROM_CORDOVA_BUILD) {\n                this.log.debug(\n                    'meteor version is < 1.3.4.2 so the index.html from cordova-build will' +\n                    ' be used'\n                );\n            } else {\n                this.log.debug(\n                    'meteor version is >= 1.3.4.2 so the index.html will be downloaded ' +\n                    'from __cordova/index.html'\n                );\n            }\n        }\n\n        if (!this.$.env.options.skipMobileBuild) {\n            const platforms = fs.readFileSync(this.$.env.paths.meteorApp.platforms, 'UTF-8');\n            if (!~platforms.indexOf('android') && !~platforms.indexOf('ios')) {\n                if (!this.$.env.options.android) {\n                    this.mobilePlatform = 'ios';\n                } else {\n                    this.mobilePlatform = 'android';\n                }\n                this.log.warn(`no mobile target detected - will add '${this.mobilePlatform}' ` +\n                    'just to get a mobile build');\n                try {\n                    await this.addMobilePlatform(this.mobilePlatform);\n                } catch (e) {\n                    this.log.error('failed to add a mobile platform - please try to do it manually');\n                    process.exit(1);\n                }\n            }\n        }\n    }\n\n    /**\n     * Tries to add a mobile platform to meteor project.\n     * @param {string} platform - platform to add\n     * @returns {Promise}\n     */\n    addMobilePlatform(platform) {\n        return new Promise((resolve, reject) => {\n            this.log.verbose(`adding mobile platform: ${platform}`);\n            spawn('meteor', ['add-platform', platform], {\n                cwd: this.$.env.paths.meteorApp.root,\n                stdio: this.$.env.stdio\n            }).on('exit', () => {\n                const platforms = fs.readFileSync(this.$.env.paths.meteorApp.platforms, 'UTF-8');\n                if (!~platforms.indexOf('android') && !~platforms.indexOf('ios')) {\n                    reject();\n                } else {\n                    resolve();\n                }\n            });\n        });\n    }\n\n    /**\n     * Tries to remove a mobile platform from meteor project.\n     * @param {string} platform - platform to remove\n     * @returns {Promise}\n     */\n    removeMobilePlatform(platform) {\n        if (this.$.env.options.skipRemoveMobilePlatform) {\n            return Promise.resolve();\n        }\n        return new Promise((resolve, reject) => {\n            this.log.verbose(`removing mobile platform: ${platform}`);\n            spawn('meteor', ['remove-platform', platform], {\n                cwd: this.$.env.paths.meteorApp.root,\n                stdio: this.$.env.stdio,\n                env: Object.assign({ METEOR_PRETTY_OUTPUT: 0 }, process.env)\n            }).on('exit', () => {\n                const platforms = fs.readFileSync(this.$.env.paths.meteorApp.platforms, 'UTF-8');\n                if (~platforms.indexOf(platform)) {\n                    reject();\n                } else {\n                    resolve();\n                }\n            });\n        });\n    }\n\n    /**\n     * Just checks for index.html and program.json existence.\n     * @returns {boolean}\n     */\n    isCordovaBuildReady() {\n        if (this.indexHTMLstrategy === this.indexHTMLStrategies.INDEX_FROM_CORDOVA_BUILD) {\n            return this.$.utils.exists(this.$.env.paths.meteorApp.cordovaBuildIndex) &&\n                this.$.utils.exists(this.$.env.paths.meteorApp.cordovaBuildProgramJson) &&\n                (\n                    !this.oldManifest ||\n                    (this.oldManifest &&\n                        this.oldManifest !== fs.readFileSync(\n                            this.$.env.paths.meteorApp.cordovaBuildProgramJson, 'UTF-8'\n                        )\n                    )\n                );\n        }\n        return this.$.utils.exists(this.$.env.paths.meteorApp.webCordovaProgramJson) &&\n            (\n                !this.oldManifest ||\n                (this.oldManifest &&\n                    this.oldManifest !== fs.readFileSync(\n                        this.$.env.paths.meteorApp.webCordovaProgramJson, 'UTF-8'\n                    )\n                )\n            );\n    }\n\n    /**\n     * Fetches index.html from running project.\n     * @returns {Promise.<*>}\n     */\n    async acquireIndex() {\n        const port = (this.$.env.options.port) ? this.$.env.options.port : 3080;\n        this.log.info('acquiring index.html');\n        const res = await fetch(`http://127.0.0.1:${port}/__cordova/index.html`);\n        const text = await res.text();\n        // Simple test if we really download index.html for web.cordova.\n        if (~text.indexOf('src=\"/cordova.js\"')) {\n            return text;\n        }\n        return false;\n    }\n\n    /**\n     * Fetches mainfest.json from running project.\n     * @returns {Promise.<void>}\n     */\n    async acquireManifest() {\n        const port = (this.$.env.options.port) ? this.$.env.options.port : 3080;\n        this.log.info('acquiring manifest.json');\n        const res = await fetch(\n            `http://127.0.0.1:${port}/__cordova/manifest.json?meteor_dont_serve_index=true`\n        );\n        const text = await res.text();\n        return JSON.parse(text);\n    }\n\n    /**\n     * Tries to get a mobile build from meteor app.\n     * In case of failure leaves a meteor.log.\n     * A lot of stuff is happening here - but the main aim is to get a mobile build from\n     * .meteor/local/cordova-build/www/application and exit as soon as possible.\n     *\n     * @returns {Promise}\n     */\n    buildMobileTarget() {\n        const programJson =\n            (this.indexHTMLstrategy === this.indexHTMLStrategies.INDEX_FROM_CORDOVA_BUILD) ?\n                this.$.env.paths.meteorApp.cordovaBuildProgramJson :\n                this.$.env.paths.meteorApp.webCordovaProgramJson;\n\n        if (this.$.utils.exists(programJson)) {\n            this.oldManifest = fs.readFileSync(programJson, 'UTF-8');\n        }\n\n        return new Promise((resolve, reject) => {\n            const self = this;\n            let log = '';\n            let desiredExit = false;\n            let buildTimeout = null;\n            let errorTimeout = null;\n            let messageTimeout = null;\n            let killTimeout = null;\n            let cordovaCheckInterval = null;\n            let portProblem = false;\n\n            function windowsKill(pid) {\n                self.log.debug(`killing pid: ${pid}`);\n                spawn.sync('taskkill', ['/pid', pid, '/f', '/t']);\n\n                // We will look for other process which might have been created outside the\n                // process tree.\n                // Lets list all node.exe processes.\n\n                const out = spawn\n                    .sync(\n                        'wmic',\n                        ['process', 'where', 'caption=\"node.exe\"', 'get', 'commandline,processid']\n                    )\n                    .stdout.toString('utf-8')\n                    .split('\\n');\n                const args = self.prepareArguments();\n                // Lets mount regex.\n                const regexV1 = new RegExp(`${args.join('\\\\s+')}\\\\s+(\\\\d+)`, 'gm');\n                const regexV2 = new RegExp(`\"${args.join('\"\\\\s+\"')}\"\\\\s+(\\\\d+)`, 'gm');\n                // No we will check for those with the matching params.\n                out.forEach((line) => {\n                    const match = regexV1.exec(line) || regexV2.exec(line) || false;\n                    if (match) {\n                        self.log.debug(`killing pid: ${match[1]}`);\n                        spawn.sync('taskkill', ['/pid', match[1], '/f', '/t']);\n                    }\n                    regexV1.lastIndex = 0;\n                    regexV2.lastIndex = 0;\n                });\n            }\n\n            function writeLog() {\n                fs.writeFileSync('meteor.log', log, 'UTF-8');\n            }\n\n            function clearTimeoutsAndIntervals() {\n                clearInterval(cordovaCheckInterval);\n                clearTimeout(buildTimeout);\n                clearTimeout(errorTimeout);\n                clearTimeout(messageTimeout);\n                clearTimeout(killTimeout);\n            }\n\n            const args = this.prepareArguments();\n\n            this.log.info(`running \"meteor ${args.join(' ')}\"... this might take a while`);\n\n            const env = { METEOR_PRETTY_OUTPUT: 0, METEOR_NO_RELEASE_CHECK: 1 };\n            if (this.$.env.options.prodDebug) {\n                env.METEOR_DESKOP_PROD_DEBUG = true;\n            }\n\n            // Lets spawn meteor.\n            const child = spawn(\n                'meteor',\n                args,\n                {\n                    env: Object.assign(env, process.env),\n                    cwd: this.$.env.paths.meteorApp.root\n                },\n                { shell: true }\n            );\n\n            // Kills the currently running meteor command.\n            function kill() {\n                sll('');\n                child.kill('SIGKILL');\n                if (self.$.env.os.isWindows) {\n                    windowsKill(child.pid);\n                }\n            }\n\n            function exit() {\n                killTimeout = setTimeout(() => {\n                    clearTimeoutsAndIntervals();\n                    desiredExit = true;\n                    kill();\n                    resolve();\n                }, 500);\n            }\n\n            function copyBuild() {\n                self.copyBuild().then(() => {\n                    exit();\n                }).catch(() => {\n                    clearTimeoutsAndIntervals();\n                    kill();\n                    writeLog();\n                    reject('copy');\n                });\n            }\n\n            cordovaCheckInterval = setInterval(() => {\n                // Check if we already have cordova-build ready.\n                if (this.isCordovaBuildReady()) {\n                    // If so, then exit immediately.\n                    if (this.indexHTMLstrategy ===\n                        this.indexHTMLStrategies.INDEX_FROM_CORDOVA_BUILD) {\n                        copyBuild();\n                    }\n                }\n            }, 1000);\n\n            child.stderr.on('data', (chunk) => {\n                const line = chunk.toString('UTF-8');\n                log += `${line}\\n`;\n                if (errorTimeout) {\n                    clearTimeout(errorTimeout);\n                }\n                // Do not exit if this is the warning for using --production.\n                // Output exceeds -> https://github.com/meteor/meteor/issues/8592\n                if (\n                    !~line.indexOf('--production') &&\n                    !~line.indexOf('Output exceeds ') &&\n                    !~line.indexOf('Node#moveTo') &&\n                    !~line.indexOf('Browserslist') &&\n                    (\n                        Array.isArray(self.$.env.options.ignoreStderr) &&\n                        self.$.env.options.ignoreStderr.every(str => !~line.indexOf(str))\n                    )\n                ) {\n                    self.log.warn('STDERR:', line);\n                    // We will exit 1s after last error in stderr.\n                    errorTimeout = setTimeout(() => {\n                        clearTimeoutsAndIntervals();\n                        kill();\n                        writeLog();\n                        reject('error');\n                    }, 1000);\n                }\n            });\n\n            child.stdout.on('data', (chunk) => {\n                const line = chunk.toString('UTF-8');\n                if (!desiredExit && line.trim().replace(/[\\n\\r\\t\\v\\f]+/gm, '') !== '') {\n                    const linesToDisplay = line.trim()\n                        .split('\\n\\r');\n                    // Only display last line from the chunk.\n                    const sanitizedLine = linesToDisplay.pop().replace(/[\\n\\r\\t\\v\\f]+/gm, '');\n                    sll(sanitizedLine);\n                }\n                log += `${line}\\n`;\n                if (~line.indexOf('after_platform_add')) {\n                    sll('');\n                    this.log.info('done... 10%');\n                }\n\n                if (~line.indexOf('Local package version')) {\n                    if (messageTimeout) {\n                        clearTimeout(messageTimeout);\n                    }\n                    messageTimeout = setTimeout(() => {\n                        sll('');\n                        this.log.info('building in progress...');\n                    }, 1500);\n                }\n\n                if (~line.indexOf('Preparing Cordova project')) {\n                    sll('');\n                    this.log.info('done... 60%');\n                }\n\n                if (~line.indexOf('Can\\'t listen on port')) {\n                    portProblem = true;\n                }\n\n                if (~line.indexOf('Your application has errors')) {\n                    if (errorTimeout) {\n                        clearTimeout(errorTimeout);\n                    }\n                    errorTimeout = setTimeout(() => {\n                        clearTimeoutsAndIntervals();\n                        kill();\n                        writeLog();\n                        reject('errorInApp');\n                    }, 1000);\n                }\n\n                if (~line.indexOf('App running at')) {\n                    copyBuild();\n                }\n            });\n\n            // When Meteor exits\n            child.on('exit', () => {\n                sll('');\n                clearTimeoutsAndIntervals();\n                if (!desiredExit) {\n                    writeLog();\n                    if (portProblem) {\n                        reject('port');\n                    } else {\n                        reject('exit');\n                    }\n                }\n            });\n\n            buildTimeout = setTimeout(() => {\n                kill();\n                writeLog();\n                reject('timeout');\n            }, this.$.env.options.buildTimeout ? this.$.env.options.buildTimeout * 1000 : 600000);\n        });\n    }\n\n    /**\n     * Replaces the DDP url that was used originally when Meteor was building the client.\n     * @param {string} indexHtml - path to index.html from the client\n     */\n    updateDdpUrl(indexHtml) {\n        let content;\n        let runtimeConfig;\n\n        try {\n            content = fs.readFileSync(indexHtml, 'UTF-8');\n        } catch (e) {\n            this.log.error(`error loading index.html file: ${e.message}`);\n            process.exit(1);\n        }\n        if (!this.matcher.test(content)) {\n            this.log.error('could not find runtime config in index file');\n            process.exit(1);\n        }\n\n        try {\n            const matches = content.match(this.matcher);\n            runtimeConfig = JSON.parse(decodeURIComponent(matches[1]));\n        } catch (e) {\n            this.log.error('could not find runtime config in index file');\n            process.exit(1);\n        }\n\n        if (this.$.env.options.ddpUrl.substr(-1, 1) !== '/') {\n            this.$.env.options.ddpUrl += '/';\n        }\n\n        runtimeConfig.ROOT_URL = this.$.env.options.ddpUrl;\n        runtimeConfig.DDP_DEFAULT_CONNECTION_URL = this.$.env.options.ddpUrl;\n\n        content = content.replace(\n            this.replacer, `$1\"${encodeURIComponent(JSON.stringify(runtimeConfig))}\"$3`\n        );\n\n        try {\n            fs.writeFileSync(indexHtml, content);\n        } catch (e) {\n            this.log.error(`error writing index.html file: ${e.message}`);\n            process.exit(1);\n        }\n        this.log.info('successfully updated ddp string in the runtime config of a mobile build' +\n            ` to ${this.$.env.options.ddpUrl}`);\n    }\n\n    /**\n     * Prepares the arguments passed to `meteor` command.\n     * @returns {string[]}\n     */\n    prepareArguments() {\n        const args = ['run', '--verbose', `--mobile-server=${this.$.env.options.ddpUrl}`];\n        if (this.$.env.isProductionBuild()) {\n            args.push('--production');\n        }\n        args.push('-p');\n        if (this.$.env.options.port) {\n            args.push(this.$.env.options.port);\n        } else {\n            args.push('3080');\n        }\n        if (this.$.env.options.meteorSettings) {\n            args.push('--settings', this.$.env.options.meteorSettings);\n        }\n        return args;\n    }\n\n    /**\n     * Validates the mobile build and copies it into electron app.\n     */\n    async copyBuild() {\n        this.log.debug('clearing build dir');\n        try {\n            await this.$.utils.rmWithRetries('-rf', this.$.env.paths.electronApp.meteorApp);\n        } catch (e) {\n            throw new Error(e);\n        }\n\n        let prefix = 'cordovaBuild';\n        let copyPathPostfix = '';\n\n        if (this.indexHTMLstrategy === this.indexHTMLStrategies.INDEX_FROM_RUNNING_SERVER) {\n            prefix = 'webCordova';\n            copyPathPostfix = `${path.sep}*`;\n            let indexHtml;\n            try {\n                fs.mkdirSync(this.$.env.paths.electronApp.meteorApp);\n                indexHtml = await this.acquireIndex();\n                fs.writeFileSync(this.$.env.paths.electronApp.meteorAppIndex, indexHtml);\n                this.log.info('successfully downloaded index.html from running meteor app');\n            } catch (e) {\n                this.log.error('error while trying to download index.html for web.cordova, ' +\n                    'be sure that you are running a mobile target or with' +\n                    ' --mobile-server: ', e);\n                throw e;\n            }\n        }\n\n        const cordovaBuild = this.$.env.paths.meteorApp[prefix];\n        const { cordovaBuildIndex } = this.$.env.paths.meteorApp;\n        const cordovaBuildProgramJson = this.$.env.paths.meteorApp[`${prefix}ProgramJson`];\n\n        if (!this.$.utils.exists(cordovaBuild)) {\n            this.log.error(`no mobile build found at ${cordovaBuild}`);\n            this.log.error('are you sure you did run meteor with --mobile-server?');\n            throw new Error('required file not present');\n        }\n\n        if (!this.$.utils.exists(cordovaBuildProgramJson)) {\n            this.log.error('no program.json found in mobile build found at ' +\n                `${cordovaBuild}`);\n            this.log.error('are you sure you did run meteor with --mobile-server?');\n            throw new Error('required file not present');\n        }\n\n        if (this.indexHTMLstrategy !== this.indexHTMLStrategies.INDEX_FROM_RUNNING_SERVER) {\n            if (!this.$.utils.exists(cordovaBuildIndex)) {\n                this.log.error('no index.html found in cordova build found at ' +\n                    `${cordovaBuild}`);\n                this.log.error('are you sure you did run meteor with --mobile-server?');\n                throw new Error('required file not present');\n            }\n        }\n\n        this.log.verbose('copying mobile build');\n        shell.cp(\n            '-R', `${cordovaBuild}${copyPathPostfix}`, this.$.env.paths.electronApp.meteorApp\n        );\n\n        // Because of various permission problems here we try to clear te path by clearing\n        // all possible restrictions.\n        shell.chmod(\n            '-R', '777', this.$.env.paths.electronApp.meteorApp\n        );\n        if (this.$.env.os.isWindows) {\n            shell.exec(`attrib -r ${this.$.env.paths.electronApp.meteorApp}${path.sep}*.* /s`);\n        }\n\n        if (this.indexHTMLstrategy === this.indexHTMLStrategies.INDEX_FROM_RUNNING_SERVER) {\n            let programJson;\n            try {\n                programJson = await this.acquireManifest();\n                fs.writeFileSync(\n                    this.$.env.paths.electronApp.meteorAppProgramJson,\n                    JSON.stringify(programJson, null, 4)\n                );\n                this.log.info('successfully downloaded manifest.json from running meteor app');\n            } catch (e) {\n                this.log.error('error while trying to download manifest.json for web.cordova,' +\n                    ' be sure that you are running a mobile target or with' +\n                    ' --mobile-server: ', e);\n                throw e;\n            }\n        }\n\n        this.log.info('mobile build copied to electron app');\n\n        this.log.debug('copy cordova.js to meteor build');\n        shell.cp(\n            join(__dirname, '..', 'skeleton', 'cordova.js'),\n            this.$.env.paths.electronApp.meteorApp\n        );\n    }\n\n    /**\n     * Injects Meteor.isDesktop\n     */\n    injectIsDesktop() {\n        this.log.info('injecting isDesktop');\n\n        let manifestJsonPath = this.$.env.paths.meteorApp.cordovaBuildProgramJson;\n        if (this.indexHTMLstrategy === this.indexHTMLStrategies.INDEX_FROM_RUNNING_SERVER) {\n            manifestJsonPath = this.$.env.paths.meteorApp.webCordovaProgramJson;\n        }\n\n        try {\n            const { manifest } = JSON.parse(\n                fs.readFileSync(manifestJsonPath, 'UTF-8')\n            );\n            let injected = false;\n            let injectedStartupDidComplete = false;\n            let result = null;\n\n            // We will search in every .js file in the manifest.\n            // We could probably detect whether this is a dev or production build and only search in\n            // the correct files, but for now this should be fine.\n            manifest.forEach((file) => {\n                let fileContents;\n                // Hacky way of setting isDesktop.\n                if (file.type === 'js') {\n                    fileContents = fs.readFileSync(\n                        join(this.$.env.paths.electronApp.meteorApp, file.path),\n                        'UTF-8'\n                    );\n                    result = this.injector.processFileContents(fileContents);\n\n                    ({ fileContents } = result);\n                    injectedStartupDidComplete =\n                        result.injectedStartupDidComplete ? true : injectedStartupDidComplete;\n                    injected = result.injected ? true : injected;\n\n                    fs.writeFileSync(\n                        join(this.$.env.paths.electronApp.meteorApp, file.path), fileContents\n                    );\n                }\n            });\n\n            if (!injected) {\n                this.log.error('error injecting isDesktop global var.');\n                process.exit(1);\n            }\n            if (!injectedStartupDidComplete) {\n                this.log.error('error injecting isDesktop for startupDidComplete');\n                process.exit(1);\n            }\n        } catch (e) {\n            this.log.error('error occurred while injecting isDesktop: ', e);\n            process.exit(1);\n        }\n        this.log.info('injected successfully');\n    }\n\n    /**\n     * Builds, modifies and copies the meteor app to electron app.\n     */\n    async build() {\n        this.log.info('checking for any mobile platform');\n        try {\n            await this.checkPreconditions();\n        } catch (e) {\n            this.log.error('error occurred during checking preconditions: ', e);\n            process.exit(1);\n        }\n\n        this.log.info('building meteor app');\n\n        if (!this.$.env.options.skipMobileBuild) {\n            try {\n                await this.buildMobileTarget();\n            } catch (reason) {\n                switch (reason) {\n                    case 'timeout':\n                        this.log.error(\n                            'timeout while building, log has been written to meteor.log'\n                        );\n                        break;\n                    case 'error':\n                        this.log.error(\n                            'build was terminated by meteor-desktop as some errors were reported to stderr, you ' +\n                            'should see it above, also check meteor.log for more info, to ignore it use the ' +\n                            '--ignore-stderr \"<string>\"'\n                        );\n                        break;\n                    case 'errorInApp':\n                        this.log.error(\n                            'your meteor app has errors - look into meteor.log for more' +\n                            ' info'\n                        );\n                        break;\n                    case 'port':\n                        this.log.error(\n                            'your port 3080 is currently used (you probably have this or other ' +\n                            'meteor project running?), use `-t` or `--meteor-port` to use ' +\n                            'different port while building'\n                        );\n                        break;\n                    case 'exit':\n                        this.log.error(\n                            'meteor cmd exited unexpectedly, log has been written to meteor.log'\n                        );\n                        break;\n                    case 'copy':\n                        this.log.error(\n                            'error encountered when copying the build'\n                        );\n                        break;\n                    default:\n                        this.log.error('error occurred during building mobile target', reason);\n                }\n                if (this.mobilePlatform) {\n                    await this.removeMobilePlatform(this.mobilePlatform);\n                }\n                process.exit(1);\n            }\n        } else {\n            this.indexHTMLstrategy = this.chooseStrategy();\n            try {\n                await this.copyBuild();\n            } catch (e) {\n                process.exit(1);\n            }\n        }\n\n        this.injectIsDesktop();\n\n        this.changeDdpUrl();\n\n        try {\n            await this.packToAsar();\n        } catch (e) {\n            this.log.error('error while packing meteor app to asar');\n            process.exit(1);\n        }\n\n        this.log.info('meteor build finished');\n\n        if (this.mobilePlatform) {\n            await this.removeMobilePlatform(this.mobilePlatform);\n        }\n    }\n\n    changeDdpUrl() {\n        if (this.$.env.options.ddpUrl !== null) {\n            try {\n                this.updateDdpUrl(this.$.env.paths.electronApp.meteorAppIndex);\n            } catch (e) {\n                this.log.error(`error while trying to change the ddp url: ${e.message}`);\n            }\n        }\n    }\n\n    packToAsar() {\n        this.log.info('packing meteor app to asar archive');\n        return new Promise((resolve, reject) =>\n            asar.createPackage(\n                this.$.env.paths.electronApp.meteorApp,\n                path.join(this.$.env.paths.electronApp.root, 'meteor.asar')\n            )\n                .then(() => {\n                    // On Windows some files might still be blocked. Giving a tick for them to be\n                    // ready for deletion.\n                    setImmediate(() => {\n                        this.log.verbose('clearing meteor app after packing');\n                        this.$.utils\n                            .rmWithRetries('-rf', this.$.env.paths.electronApp.meteorApp)\n                            .then(() => {\n                                resolve();\n                            })\n                            .catch((e) => {\n                                reject(e);\n                            });\n                    });\n                }));\n    }\n\n    /**\n     * Wrapper for spawning npm.\n     * @param {Array}  commands - commands for spawn\n     * @param {string} stdio\n     * @param {string} cwd\n     * @return {Promise}\n     */\n    runNpm(commands, stdio = 'ignore', cwd = this.$.env.paths.meteorApp.root) {\n        return new Promise((resolve, reject) => {\n            this.log.verbose(`executing meteor npm ${commands.join(' ')}`);\n\n            spawn('meteor', ['npm', ...commands], {\n                cwd,\n                stdio\n            }).on('exit', code => (\n                (code === 0) ? resolve() : reject(new Error(`npm exit code was ${code}`))\n            ));\n        });\n    }\n}\n"],"mappings":"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"}
\ No newline at end of file
diff --git a/dist/meteorManager.js b/dist/meteorManager.js
new file mode 100644
index 00000000..098723b3
--- /dev/null
+++ b/dist/meteorManager.js
@@ -0,0 +1,147 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = void 0;
+
+var _runtime = _interopRequireDefault(require("regenerator-runtime/runtime"));
+
+var _fs = _interopRequireDefault(require("fs"));
+
+var _crossSpawn = _interopRequireDefault(require("cross-spawn"));
+
+var _log = _interopRequireDefault(require("./log"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+// eslint-disable-next-line no-unused-vars
+
+/**
+ * Utility class designed for managing Meteor packages.
+ *
+ * @property {MeteorDesktop} $
+ * @class
+ */
+class MeteorManager {
+ /**
+ * @param {MeteorDesktop} $ - context
+ * @constructor
+ */
+ constructor($) {
+ this.log = new _log.default('meteorManager');
+ this.$ = $;
+ }
+ /**
+ * Looks for specified packages in .meteor/packages. In other words checks if the project has
+ * specified packages added.
+ * @param {Array} packages
+ * @returns {boolean}
+ */
+
+
+ checkPackages(packages) {
+ const usedPackages = _fs.default.readFileSync(this.$.env.paths.meteorApp.packages, 'UTF-8').replace(/\r/gm, '').split('\n').filter(line => !line.trim().startsWith('#'));
+
+ return !packages.some(packageToFind => !usedPackages.some(meteorPackage => ~meteorPackage.indexOf(packageToFind)));
+ }
+ /**
+ * Looks for specified packages in .meteor/packages. In other words checks if the project has
+ * specified packages added.
+ * @param {Array} packages
+ * @returns {boolean}
+ */
+
+
+ checkPackagesVersion(packages) {
+ const usedPackages = _fs.default.readFileSync(this.$.env.paths.meteorApp.versions, 'UTF-8').replace(/\r/gm, '').split('\n');
+
+ return !packages.some(packageToFind => !usedPackages.some(meteorPackage => meteorPackage === packageToFind));
+ }
+ /**
+ * Ensures certain packages are added to meteor project and in correct version.
+ * @param {Array} packages
+ * @param {Array} packagesWithVersion
+ * @param {string} who - name of the entity that requests presence of thos packages (can be the
+ * integration itself or a plugin)
+ * @returns {Promise.}
+ */
+
+
+ async ensurePackages(packages, packagesWithVersion, who) {
+ if (!this.checkPackages(packages)) {
+ this.log.warn(`${who} requires some packages that are not added to project, will try to add them now`);
+
+ try {
+ await this.addPackages(packages, packagesWithVersion);
+ } catch (e) {
+ throw new Error(e);
+ }
+ }
+
+ if (!this.checkPackagesVersion(packagesWithVersion)) {
+ this.log.warn(`${who} required packages version is different, fixing it`);
+
+ try {
+ await this.addPackages(packages, packagesWithVersion);
+ } catch (e) {
+ throw new Error(e);
+ }
+ }
+ }
+ /**
+ * Removes packages from the meteor app.
+ * @param {Array} packages - array with names of the packages to remove
+ */
+
+
+ deletePackages(packages) {
+ this.log.warn('removing packages from meteor project', ...packages);
+ return new Promise((resolve, reject) => {
+ (0, _crossSpawn.default)('meteor', ['remove'].concat(packages), {
+ cwd: this.$.env.paths.meteorApp.root,
+ stdio: ['pipe', 'pipe', process.stderr],
+ env: Object.assign({
+ METEOR_PRETTY_OUTPUT: 0,
+ METEOR_NO_RELEASE_CHECK: 1
+ }, process.env)
+ }).on('exit', code => {
+ if (code !== 0 || this.checkPackages(packages)) {
+ reject('removing packages failed');
+ } else {
+ resolve();
+ }
+ });
+ });
+ }
+ /**
+ * Adds packages to the meteor app.
+ * @param {Array} packages - array with names of the packages to add
+ * @param {Array} packagesWithVersion - array with names and versions of the packages to add
+ */
+
+
+ addPackages(packages, packagesWithVersion) {
+ this.log.info('adding packages to meteor project', ...packagesWithVersion);
+ return new Promise((resolve, reject) => {
+ (0, _crossSpawn.default)('meteor', ['add'].concat(packagesWithVersion.map(packageName => packageName.replace('@', '@='))), {
+ cwd: this.$.env.paths.meteorApp.root,
+ stdio: ['pipe', 'pipe', process.stderr],
+ env: Object.assign({
+ METEOR_PRETTY_OUTPUT: 0,
+ METEOR_NO_RELEASE_CHECK: 1
+ }, process.env)
+ }).on('exit', code => {
+ if (code !== 0 || !this.checkPackages(packages)) {
+ reject('adding packages failed');
+ } else {
+ resolve();
+ }
+ });
+ });
+ }
+
+}
+
+exports.default = MeteorManager;
+//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["MeteorManager","constructor","$","log","Log","checkPackages","packages","usedPackages","fs","readFileSync","env","paths","meteorApp","replace","split","filter","line","trim","startsWith","some","packageToFind","meteorPackage","indexOf","checkPackagesVersion","versions","ensurePackages","packagesWithVersion","who","warn","addPackages","e","Error","deletePackages","Promise","resolve","reject","spawn","concat","cwd","root","stdio","process","stderr","Object","assign","METEOR_PRETTY_OUTPUT","METEOR_NO_RELEASE_CHECK","on","code","info","map","packageName"],"sources":["../lib/meteorManager.js"],"sourcesContent":["// eslint-disable-next-line no-unused-vars\nimport regeneratorRuntime from 'regenerator-runtime/runtime';\nimport fs from 'fs';\nimport spawn from 'cross-spawn';\n\nimport Log from './log';\n\n/**\n * Utility class designed for managing Meteor packages.\n *\n * @property {MeteorDesktop} $\n * @class\n */\nexport default class MeteorManager {\n    /**\n     * @param {MeteorDesktop} $ - context\n     * @constructor\n     */\n    constructor($) {\n        this.log = new Log('meteorManager');\n        this.$ = $;\n    }\n\n    /**\n     * Looks for specified packages in .meteor/packages. In other words checks if the project has\n     * specified packages added.\n     * @param {Array} packages\n     * @returns {boolean}\n     */\n    checkPackages(packages) {\n        const usedPackages = fs\n            .readFileSync(this.$.env.paths.meteorApp.packages, 'UTF-8')\n            .replace(/\\r/gm, '')\n            .split('\\n')\n            .filter(line => !line.trim().startsWith('#'));\n        return !packages.some(\n            packageToFind =>\n                !usedPackages.some(meteorPackage => ~meteorPackage.indexOf(packageToFind))\n        );\n    }\n\n    /**\n     * Looks for specified packages in .meteor/packages. In other words checks if the project has\n     * specified packages added.\n     * @param {Array} packages\n     * @returns {boolean}\n     */\n    checkPackagesVersion(packages) {\n        const usedPackages = fs.readFileSync(this.$.env.paths.meteorApp.versions, 'UTF-8')\n            .replace(/\\r/gm, '')\n            .split('\\n');\n        return !packages.some(\n            packageToFind => !usedPackages.some(meteorPackage => meteorPackage === packageToFind)\n        );\n    }\n\n    /**\n     * Ensures certain packages are added to meteor project and in correct version.\n     * @param {Array} packages\n     * @param {Array} packagesWithVersion\n     * @param {string} who - name of the entity that requests presence of thos packages (can be the\n     *                       integration itself or a plugin)\n     * @returns {Promise.<void>}\n     */\n    async ensurePackages(packages, packagesWithVersion, who) {\n        if (!this.checkPackages(packages)) {\n            this.log.warn(`${who} requires some packages that are not added to project, will try to add them now`);\n            try {\n                await this.addPackages(packages, packagesWithVersion);\n            } catch (e) {\n                throw new Error(e);\n            }\n        }\n        if (!this.checkPackagesVersion(packagesWithVersion)) {\n            this.log.warn(`${who} required packages version is different, fixing it`);\n            try {\n                await this.addPackages(packages, packagesWithVersion);\n            } catch (e) {\n                throw new Error(e);\n            }\n        }\n    }\n\n    /**\n     * Removes packages from the meteor app.\n     * @param {Array} packages            - array with names of the packages to remove\n     */\n    deletePackages(packages) {\n        this.log.warn('removing packages from meteor project', ...packages);\n        return new Promise((resolve, reject) => {\n            spawn(\n                'meteor',\n                ['remove'].concat(packages), {\n                    cwd: this.$.env.paths.meteorApp.root,\n                    stdio: ['pipe', 'pipe', process.stderr],\n                    env: Object.assign(\n                        { METEOR_PRETTY_OUTPUT: 0, METEOR_NO_RELEASE_CHECK: 1 }, process.env\n                    )\n                }\n            ).on('exit', (code) => {\n                if (code !== 0 || this.checkPackages(packages)) {\n                    reject('removing packages failed');\n                } else {\n                    resolve();\n                }\n            });\n        });\n    }\n\n    /**\n     * Adds packages to the meteor app.\n     * @param {Array} packages            - array with names of the packages to add\n     * @param {Array} packagesWithVersion - array with names and versions of the packages to add\n     */\n    addPackages(packages, packagesWithVersion) {\n        this.log.info('adding packages to meteor project', ...packagesWithVersion);\n        return new Promise((resolve, reject) => {\n            spawn(\n                'meteor',\n                ['add'].concat(\n                    packagesWithVersion.map(packageName => packageName.replace('@', '@='))\n                ),\n                {\n                    cwd: this.$.env.paths.meteorApp.root,\n                    stdio: ['pipe', 'pipe', process.stderr],\n                    env: Object.assign(\n                        { METEOR_PRETTY_OUTPUT: 0, METEOR_NO_RELEASE_CHECK: 1 }, process.env\n                    )\n                }\n            ).on('exit', (code) => {\n                if (code !== 0 || !this.checkPackages(packages)) {\n                    reject('adding packages failed');\n                } else {\n                    resolve();\n                }\n            });\n        });\n    }\n}\n"],"mappings":";;;;;;;AACA;;AACA;;AACA;;AAEA;;;;AALA;;AAOA;AACA;AACA;AACA;AACA;AACA;AACe,MAAMA,aAAN,CAAoB;EAC/B;AACJ;AACA;AACA;EACIC,WAAW,CAACC,CAAD,EAAI;IACX,KAAKC,GAAL,GAAW,IAAIC,YAAJ,CAAQ,eAAR,CAAX;IACA,KAAKF,CAAL,GAASA,CAAT;EACH;EAED;AACJ;AACA;AACA;AACA;AACA;;;EACIG,aAAa,CAACC,QAAD,EAAW;IACpB,MAAMC,YAAY,GAAGC,WAAA,CAChBC,YADgB,CACH,KAAKP,CAAL,CAAOQ,GAAP,CAAWC,KAAX,CAAiBC,SAAjB,CAA2BN,QADxB,EACkC,OADlC,EAEhBO,OAFgB,CAER,MAFQ,EAEA,EAFA,EAGhBC,KAHgB,CAGV,IAHU,EAIhBC,MAJgB,CAITC,IAAI,IAAI,CAACA,IAAI,CAACC,IAAL,GAAYC,UAAZ,CAAuB,GAAvB,CAJA,CAArB;;IAKA,OAAO,CAACZ,QAAQ,CAACa,IAAT,CACJC,aAAa,IACT,CAACb,YAAY,CAACY,IAAb,CAAkBE,aAAa,IAAI,CAACA,aAAa,CAACC,OAAd,CAAsBF,aAAtB,CAApC,CAFD,CAAR;EAIH;EAED;AACJ;AACA;AACA;AACA;AACA;;;EACIG,oBAAoB,CAACjB,QAAD,EAAW;IAC3B,MAAMC,YAAY,GAAGC,WAAA,CAAGC,YAAH,CAAgB,KAAKP,CAAL,CAAOQ,GAAP,CAAWC,KAAX,CAAiBC,SAAjB,CAA2BY,QAA3C,EAAqD,OAArD,EAChBX,OADgB,CACR,MADQ,EACA,EADA,EAEhBC,KAFgB,CAEV,IAFU,CAArB;;IAGA,OAAO,CAACR,QAAQ,CAACa,IAAT,CACJC,aAAa,IAAI,CAACb,YAAY,CAACY,IAAb,CAAkBE,aAAa,IAAIA,aAAa,KAAKD,aAArD,CADd,CAAR;EAGH;EAED;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;;;EACwB,MAAdK,cAAc,CAACnB,QAAD,EAAWoB,mBAAX,EAAgCC,GAAhC,EAAqC;IACrD,IAAI,CAAC,KAAKtB,aAAL,CAAmBC,QAAnB,CAAL,EAAmC;MAC/B,KAAKH,GAAL,CAASyB,IAAT,CAAe,GAAED,GAAI,iFAArB;;MACA,IAAI;QACA,MAAM,KAAKE,WAAL,CAAiBvB,QAAjB,EAA2BoB,mBAA3B,CAAN;MACH,CAFD,CAEE,OAAOI,CAAP,EAAU;QACR,MAAM,IAAIC,KAAJ,CAAUD,CAAV,CAAN;MACH;IACJ;;IACD,IAAI,CAAC,KAAKP,oBAAL,CAA0BG,mBAA1B,CAAL,EAAqD;MACjD,KAAKvB,GAAL,CAASyB,IAAT,CAAe,GAAED,GAAI,oDAArB;;MACA,IAAI;QACA,MAAM,KAAKE,WAAL,CAAiBvB,QAAjB,EAA2BoB,mBAA3B,CAAN;MACH,CAFD,CAEE,OAAOI,CAAP,EAAU;QACR,MAAM,IAAIC,KAAJ,CAAUD,CAAV,CAAN;MACH;IACJ;EACJ;EAED;AACJ;AACA;AACA;;;EACIE,cAAc,CAAC1B,QAAD,EAAW;IACrB,KAAKH,GAAL,CAASyB,IAAT,CAAc,uCAAd,EAAuD,GAAGtB,QAA1D;IACA,OAAO,IAAI2B,OAAJ,CAAY,CAACC,OAAD,EAAUC,MAAV,KAAqB;MACpC,IAAAC,mBAAA,EACI,QADJ,EAEI,CAAC,QAAD,EAAWC,MAAX,CAAkB/B,QAAlB,CAFJ,EAEiC;QACzBgC,GAAG,EAAE,KAAKpC,CAAL,CAAOQ,GAAP,CAAWC,KAAX,CAAiBC,SAAjB,CAA2B2B,IADP;QAEzBC,KAAK,EAAE,CAAC,MAAD,EAAS,MAAT,EAAiBC,OAAO,CAACC,MAAzB,CAFkB;QAGzBhC,GAAG,EAAEiC,MAAM,CAACC,MAAP,CACD;UAAEC,oBAAoB,EAAE,CAAxB;UAA2BC,uBAAuB,EAAE;QAApD,CADC,EACwDL,OAAO,CAAC/B,GADhE;MAHoB,CAFjC,EASEqC,EATF,CASK,MATL,EAScC,IAAD,IAAU;QACnB,IAAIA,IAAI,KAAK,CAAT,IAAc,KAAK3C,aAAL,CAAmBC,QAAnB,CAAlB,EAAgD;UAC5C6B,MAAM,CAAC,0BAAD,CAAN;QACH,CAFD,MAEO;UACHD,OAAO;QACV;MACJ,CAfD;IAgBH,CAjBM,CAAP;EAkBH;EAED;AACJ;AACA;AACA;AACA;;;EACIL,WAAW,CAACvB,QAAD,EAAWoB,mBAAX,EAAgC;IACvC,KAAKvB,GAAL,CAAS8C,IAAT,CAAc,mCAAd,EAAmD,GAAGvB,mBAAtD;IACA,OAAO,IAAIO,OAAJ,CAAY,CAACC,OAAD,EAAUC,MAAV,KAAqB;MACpC,IAAAC,mBAAA,EACI,QADJ,EAEI,CAAC,KAAD,EAAQC,MAAR,CACIX,mBAAmB,CAACwB,GAApB,CAAwBC,WAAW,IAAIA,WAAW,CAACtC,OAAZ,CAAoB,GAApB,EAAyB,IAAzB,CAAvC,CADJ,CAFJ,EAKI;QACIyB,GAAG,EAAE,KAAKpC,CAAL,CAAOQ,GAAP,CAAWC,KAAX,CAAiBC,SAAjB,CAA2B2B,IADpC;QAEIC,KAAK,EAAE,CAAC,MAAD,EAAS,MAAT,EAAiBC,OAAO,CAACC,MAAzB,CAFX;QAGIhC,GAAG,EAAEiC,MAAM,CAACC,MAAP,CACD;UAAEC,oBAAoB,EAAE,CAAxB;UAA2BC,uBAAuB,EAAE;QAApD,CADC,EACwDL,OAAO,CAAC/B,GADhE;MAHT,CALJ,EAYEqC,EAZF,CAYK,MAZL,EAYcC,IAAD,IAAU;QACnB,IAAIA,IAAI,KAAK,CAAT,IAAc,CAAC,KAAK3C,aAAL,CAAmBC,QAAnB,CAAnB,EAAiD;UAC7C6B,MAAM,CAAC,wBAAD,CAAN;QACH,CAFD,MAEO;UACHD,OAAO;QACV;MACJ,CAlBD;IAmBH,CApBM,CAAP;EAqBH;;AA5H8B"}
\ No newline at end of file
diff --git a/dist/packager.js b/dist/packager.js
new file mode 100644
index 00000000..5dc2f01f
--- /dev/null
+++ b/dist/packager.js
@@ -0,0 +1,142 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = void 0;
+
+var _runtime = _interopRequireDefault(require("regenerator-runtime/runtime"));
+
+var _assignIn = _interopRequireDefault(require("lodash/assignIn"));
+
+var _path = _interopRequireDefault(require("path"));
+
+var _fs = _interopRequireDefault(require("fs"));
+
+var _shelljs = _interopRequireDefault(require("shelljs"));
+
+var _log = _interopRequireDefault(require("./log"));
+
+var _defaultDependencies = _interopRequireDefault(require("./defaultDependencies"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+// eslint-disable-next-line no-unused-vars
+const {
+ join
+} = _path.default;
+/**
+ * Wrapper around electron-packager.
+ * @class
+ */
+
+class ElectronPackager {
+ constructor($) {
+ this.log = new _log.default('electron-packager');
+ this.$ = $;
+ }
+
+ async init() {
+ this.packager = (await this.$.getDependency('electron-packager', _defaultDependencies.default['electron-packager'])).dependency;
+ }
+ /**
+ * Runs the packager with provided arguments.
+ *
+ * @param {Object} args
+ * @returns {Promise}
+ */
+
+
+ runPackager(args) {
+ return new Promise((resolve, reject) => {
+ this.packager(args, err => {
+ if (err) {
+ reject(err);
+ } else {
+ this.log.info(`wrote packaged app to ${this.$.env.paths.packageDir}`);
+ resolve();
+ }
+ });
+ });
+ }
+
+ async packageApp() {
+ const {
+ version
+ } = JSON.parse(_fs.default.readFileSync(join(this.$.env.paths.meteorApp.root, 'node_modules', 'electron', 'package.json'), 'UTF-8'));
+ const settings = this.$.desktop.getSettings();
+ const {
+ name
+ } = settings;
+
+ if (!name) {
+ this.log.error('`name` field in settings.json not set');
+ process.exit(1);
+ }
+
+ const arch = this.$.env.options.ia32 ? 'ia32' : 'x64';
+ this.log.info(`packaging '${name}' for platform '${this.$.env.sys.platform}-${arch}'` + ` using electron v${version}`);
+
+ try {
+ await this.$.utils.rmWithRetries('-rf', _path.default.join(this.$.env.options.output, this.$.env.paths.packageDir));
+ } catch (e) {
+ throw new Error(e);
+ }
+
+ const args = {
+ name,
+ arch,
+ prune: false,
+ electronVersion: version,
+ platform: this.$.env.sys.platform,
+ dir: this.$.env.paths.electronApp.root,
+ out: _path.default.join(this.$.env.options.output, this.$.env.paths.packageDir)
+ };
+
+ if ('packagerOptions' in settings) {
+ const {
+ packagerOptions
+ } = settings;
+ ['windows', 'linux', 'osx'].forEach(system => {
+ if (this.$.env.os[`is${system[0].toUpperCase()}${system.substring(1)}`] && `_${system}` in packagerOptions) {
+ (0, _assignIn.default)(packagerOptions, packagerOptions[`_${system}`]);
+ }
+ });
+ Object.keys(packagerOptions).forEach(field => {
+ if (packagerOptions[field] === '@version') {
+ packagerOptions[field] = settings.version;
+ }
+ });
+ (0, _assignIn.default)(args, packagerOptions);
+ } // Move node_modules away. We do not want to delete it, just temporarily remove it from
+ // our way.
+
+
+ _fs.default.renameSync(this.$.env.paths.electronApp.nodeModules, this.$.env.paths.electronApp.tmpNodeModules);
+
+ let extracted = false;
+
+ if (this.$.utils.exists(this.$.env.paths.electronApp.extractedNodeModules)) {
+ _fs.default.renameSync(this.$.env.paths.electronApp.extractedNodeModules, this.$.env.paths.electronApp.nodeModules);
+
+ extracted = true;
+ }
+
+ try {
+ await this.runPackager(args);
+ } finally {
+ if (extracted) {
+ _shelljs.default.rm('-rf', this.$.env.paths.electronApp.extractedNodeModules);
+
+ _shelljs.default.rm('-rf', this.$.env.paths.electronApp.nodeModules);
+ } // Move node_modules back.
+
+
+ _fs.default.renameSync(this.$.env.paths.electronApp.tmpNodeModules, this.$.env.paths.electronApp.nodeModules);
+ }
+ }
+
+}
+
+exports.default = ElectronPackager;
+//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["join","path","ElectronPackager","constructor","$","log","Log","init","packager","getDependency","defaultDependencies","dependency","runPackager","args","Promise","resolve","reject","err","info","env","paths","packageDir","packageApp","version","JSON","parse","fs","readFileSync","meteorApp","root","settings","desktop","getSettings","name","error","process","exit","arch","options","ia32","sys","platform","utils","rmWithRetries","output","e","Error","prune","electronVersion","dir","electronApp","out","packagerOptions","forEach","system","os","toUpperCase","substring","assignIn","Object","keys","field","renameSync","nodeModules","tmpNodeModules","extracted","exists","extractedNodeModules","shell","rm"],"sources":["../lib/packager.js"],"sourcesContent":["// eslint-disable-next-line no-unused-vars\nimport regeneratorRuntime from 'regenerator-runtime/runtime';\nimport assignIn from 'lodash/assignIn';\nimport path from 'path';\nimport fs from 'fs';\nimport shell from 'shelljs';\n\nimport Log from './log';\nimport defaultDependencies from './defaultDependencies';\n\nconst { join } = path;\n\n/**\n * Wrapper around electron-packager.\n * @class\n */\nexport default class ElectronPackager {\n    constructor($) {\n        this.log = new Log('electron-packager');\n        this.$ = $;\n    }\n\n    async init() {\n        this.packager = (await this.$.getDependency('electron-packager', defaultDependencies['electron-packager'])).dependency;\n    }\n\n    /**\n     * Runs the packager with provided arguments.\n     *\n     * @param {Object} args\n     * @returns {Promise}\n     */\n    runPackager(args) {\n        return new Promise((resolve, reject) => {\n            this.packager(args, (err) => {\n                if (err) {\n                    reject(err);\n                } else {\n                    this.log.info(`wrote packaged app to ${this.$.env.paths.packageDir}`);\n                    resolve();\n                }\n            });\n        });\n    }\n\n    async packageApp() {\n        const { version } = JSON.parse(fs.readFileSync(\n            join(\n                this.$.env.paths.meteorApp.root,\n                'node_modules',\n                'electron',\n                'package.json'\n            ), 'UTF-8'\n        ));\n\n        const settings = this.$.desktop.getSettings();\n        const { name } = settings;\n        if (!name) {\n            this.log.error('`name` field in settings.json not set');\n            process.exit(1);\n        }\n\n        const arch = this.$.env.options.ia32 ? 'ia32' : 'x64';\n\n        this.log.info(\n            `packaging '${name}' for platform '${this.$.env.sys.platform}-${arch}'` +\n            ` using electron v${version}`\n        );\n\n        try {\n            await this.$.utils.rmWithRetries(\n                '-rf', path.join(this.$.env.options.output, this.$.env.paths.packageDir)\n            );\n        } catch (e) {\n            throw new Error(e);\n        }\n\n        const args = {\n            name,\n            arch,\n            prune: false,\n            electronVersion: version,\n            platform: this.$.env.sys.platform,\n            dir: this.$.env.paths.electronApp.root,\n            out: path.join(this.$.env.options.output, this.$.env.paths.packageDir)\n        };\n\n        if ('packagerOptions' in settings) {\n            const { packagerOptions } = settings;\n\n            ['windows', 'linux', 'osx'].forEach((system) => {\n                if (\n                    this.$.env.os[`is${system[0].toUpperCase()}${system.substring(1)}`] &&\n                    (`_${system}`) in packagerOptions\n                ) {\n                    assignIn(packagerOptions, packagerOptions[`_${system}`]);\n                }\n            });\n\n            Object.keys(packagerOptions).forEach((field) => {\n                if (packagerOptions[field] === '@version') {\n                    packagerOptions[field] = settings.version;\n                }\n            });\n\n            assignIn(args, packagerOptions);\n        }\n\n        // Move node_modules away. We do not want to delete it, just temporarily remove it from\n        // our way.\n        fs.renameSync(\n            this.$.env.paths.electronApp.nodeModules,\n            this.$.env.paths.electronApp.tmpNodeModules\n        );\n\n        let extracted = false;\n\n        if (this.$.utils.exists(this.$.env.paths.electronApp.extractedNodeModules)) {\n            fs.renameSync(\n                this.$.env.paths.electronApp.extractedNodeModules,\n                this.$.env.paths.electronApp.nodeModules\n            );\n            extracted = true;\n        }\n\n        try {\n            await this.runPackager(args);\n        } finally {\n            if (extracted) {\n                shell.rm('-rf', this.$.env.paths.electronApp.extractedNodeModules);\n                shell.rm('-rf', this.$.env.paths.electronApp.nodeModules);\n            }\n            // Move node_modules back.\n            fs.renameSync(\n                this.$.env.paths.electronApp.tmpNodeModules,\n                this.$.env.paths.electronApp.nodeModules\n            );\n        }\n    }\n}\n"],"mappings":"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"}
\ No newline at end of file
diff --git a/dist/scripts/addToScripts.js b/dist/scripts/addToScripts.js
new file mode 100644
index 00000000..aa8d2507
--- /dev/null
+++ b/dist/scripts/addToScripts.js
@@ -0,0 +1,24 @@
+"use strict";
+
+var _path = _interopRequireDefault(require("path"));
+
+var _addScript = _interopRequireDefault(require("./utils/addScript"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/* eslint-disable no-console */
+
+/**
+ * This script adds a 'desktop' entry to 'scripts' in package.json. If the entry already exists
+ * it leaves it untouched.
+ */
+function fail() {
+ console.error('[meteor-desktop] failed to add meteor-desktop to your package.json scripts, ' + 'please add it manually as \'desktop\': \'meteor-desktop\'');
+ process.exit(0);
+}
+
+const packageJsonPath = _path.default.resolve(_path.default.join(__dirname, '..', '..', '..', '..', 'package.json'));
+
+(0, _addScript.default)('desktop', 'meteor-desktop', packageJsonPath, fail);
+console.log('[meteor-desktop] successfully added a \'desktop\' entry to your package.json' + ' scripts section.');
+//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJmYWlsIiwiY29uc29sZSIsImVycm9yIiwicHJvY2VzcyIsImV4aXQiLCJwYWNrYWdlSnNvblBhdGgiLCJwYXRoIiwicmVzb2x2ZSIsImpvaW4iLCJfX2Rpcm5hbWUiLCJhZGRTY3JpcHQiLCJsb2ciXSwic291cmNlcyI6WyIuLi8uLi9saWIvc2NyaXB0cy9hZGRUb1NjcmlwdHMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgbm8tY29uc29sZSAqL1xuaW1wb3J0IHBhdGggZnJvbSAncGF0aCc7XG5cbmltcG9ydCBhZGRTY3JpcHQgZnJvbSAnLi91dGlscy9hZGRTY3JpcHQnO1xuLyoqXG4gKiBUaGlzIHNjcmlwdCBhZGRzIGEgJ2Rlc2t0b3AnIGVudHJ5IHRvICdzY3JpcHRzJyBpbiBwYWNrYWdlLmpzb24uIElmIHRoZSBlbnRyeSBhbHJlYWR5IGV4aXN0c1xuICogaXQgbGVhdmVzIGl0IHVudG91Y2hlZC5cbiAqL1xuZnVuY3Rpb24gZmFpbCgpIHtcbiAgICBjb25zb2xlLmVycm9yKCdbbWV0ZW9yLWRlc2t0b3BdIGZhaWxlZCB0byBhZGQgbWV0ZW9yLWRlc2t0b3AgdG8geW91ciBwYWNrYWdlLmpzb24gc2NyaXB0cywgJyArXG4gICAgICAgICdwbGVhc2UgYWRkIGl0IG1hbnVhbGx5IGFzIFxcJ2Rlc2t0b3BcXCc6IFxcJ21ldGVvci1kZXNrdG9wXFwnJyk7XG4gICAgcHJvY2Vzcy5leGl0KDApO1xufVxuXG5jb25zdCBwYWNrYWdlSnNvblBhdGggPSBwYXRoLnJlc29sdmUoXG4gICAgcGF0aC5qb2luKF9fZGlybmFtZSwgJy4uJywgJy4uJywgJy4uJywgJy4uJywgJ3BhY2thZ2UuanNvbicpXG4pO1xuXG5hZGRTY3JpcHQoJ2Rlc2t0b3AnLCAnbWV0ZW9yLWRlc2t0b3AnLCBwYWNrYWdlSnNvblBhdGgsIGZhaWwpO1xuXG5jb25zb2xlLmxvZygnW21ldGVvci1kZXNrdG9wXSBzdWNjZXNzZnVsbHkgYWRkZWQgYSBcXCdkZXNrdG9wXFwnIGVudHJ5IHRvIHlvdXIgcGFja2FnZS5qc29uJyArXG4gICAgJyBzY3JpcHRzIHNlY3Rpb24uJyk7XG4iXSwibWFwcGluZ3MiOiI7O0FBQ0E7O0FBRUE7Ozs7QUFIQTs7QUFJQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVNBLElBQVQsR0FBZ0I7RUFDWkMsT0FBTyxDQUFDQyxLQUFSLENBQWMsaUZBQ1YsMkRBREo7RUFFQUMsT0FBTyxDQUFDQyxJQUFSLENBQWEsQ0FBYjtBQUNIOztBQUVELE1BQU1DLGVBQWUsR0FBR0MsYUFBQSxDQUFLQyxPQUFMLENBQ3BCRCxhQUFBLENBQUtFLElBQUwsQ0FBVUMsU0FBVixFQUFxQixJQUFyQixFQUEyQixJQUEzQixFQUFpQyxJQUFqQyxFQUF1QyxJQUF2QyxFQUE2QyxjQUE3QyxDQURvQixDQUF4Qjs7QUFJQSxJQUFBQyxrQkFBQSxFQUFVLFNBQVYsRUFBcUIsZ0JBQXJCLEVBQXVDTCxlQUF2QyxFQUF3REwsSUFBeEQ7QUFFQUMsT0FBTyxDQUFDVSxHQUFSLENBQVksaUZBQ1IsbUJBREoifQ==
\ No newline at end of file
diff --git a/dist/scripts/propagateVersion.js b/dist/scripts/propagateVersion.js
new file mode 100644
index 00000000..eb548ed1
--- /dev/null
+++ b/dist/scripts/propagateVersion.js
@@ -0,0 +1,21 @@
+"use strict";
+
+// This propagates the version from package.json to Meteor plugins.
+const {
+ version
+} = require('../../package.json');
+
+const fs = require('fs');
+
+const paths = ['./plugins/bundler/package.js', './plugins/watcher/package.js'];
+paths.forEach(path => {
+ let packageJs = fs.readFileSync(path, 'UTF-8');
+ packageJs = packageJs.replace(/(version: ')([^']+)'/, `$1${version}'`);
+
+ if (~path.indexOf('watcher')) {
+ packageJs = packageJs.replace(/(communitypackages:meteor-desktop-bundler@)([^']+)'/, `$1${version}'`);
+ }
+
+ fs.writeFileSync(path, packageJs);
+});
+//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJ2ZXJzaW9uIiwicmVxdWlyZSIsImZzIiwicGF0aHMiLCJmb3JFYWNoIiwicGF0aCIsInBhY2thZ2VKcyIsInJlYWRGaWxlU3luYyIsInJlcGxhY2UiLCJpbmRleE9mIiwid3JpdGVGaWxlU3luYyJdLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9zY3JpcHRzL3Byb3BhZ2F0ZVZlcnNpb24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiLy8gVGhpcyBwcm9wYWdhdGVzIHRoZSB2ZXJzaW9uIGZyb20gcGFja2FnZS5qc29uIHRvIE1ldGVvciBwbHVnaW5zLlxuXG5jb25zdCB7IHZlcnNpb24gfSA9IHJlcXVpcmUoJy4uLy4uL3BhY2thZ2UuanNvbicpO1xuY29uc3QgZnMgPSByZXF1aXJlKCdmcycpO1xuXG5jb25zdCBwYXRocyA9IFsnLi9wbHVnaW5zL2J1bmRsZXIvcGFja2FnZS5qcycsICcuL3BsdWdpbnMvd2F0Y2hlci9wYWNrYWdlLmpzJ107XG5wYXRocy5mb3JFYWNoKChwYXRoKSA9PiB7XG4gICAgbGV0IHBhY2thZ2VKcyA9IGZzLnJlYWRGaWxlU3luYyhwYXRoLCAnVVRGLTgnKTtcbiAgICBwYWNrYWdlSnMgPSBwYWNrYWdlSnMucmVwbGFjZSgvKHZlcnNpb246ICcpKFteJ10rKScvLCBgJDEke3ZlcnNpb259J2ApO1xuICAgIGlmICh+cGF0aC5pbmRleE9mKCd3YXRjaGVyJykpIHtcbiAgICAgICAgcGFja2FnZUpzID0gcGFja2FnZUpzLnJlcGxhY2UoLyhjb21tdW5pdHlwYWNrYWdlczptZXRlb3ItZGVza3RvcC1idW5kbGVyQCkoW14nXSspJy8sIGAkMSR7dmVyc2lvbn0nYCk7XG4gICAgfVxuICAgIGZzLndyaXRlRmlsZVN5bmMocGF0aCwgcGFja2FnZUpzKTtcbn0pO1xuIl0sIm1hcHBpbmdzIjoiOztBQUFBO0FBRUEsTUFBTTtFQUFFQTtBQUFGLElBQWNDLE9BQU8sQ0FBQyxvQkFBRCxDQUEzQjs7QUFDQSxNQUFNQyxFQUFFLEdBQUdELE9BQU8sQ0FBQyxJQUFELENBQWxCOztBQUVBLE1BQU1FLEtBQUssR0FBRyxDQUFDLDhCQUFELEVBQWlDLDhCQUFqQyxDQUFkO0FBQ0FBLEtBQUssQ0FBQ0MsT0FBTixDQUFlQyxJQUFELElBQVU7RUFDcEIsSUFBSUMsU0FBUyxHQUFHSixFQUFFLENBQUNLLFlBQUgsQ0FBZ0JGLElBQWhCLEVBQXNCLE9BQXRCLENBQWhCO0VBQ0FDLFNBQVMsR0FBR0EsU0FBUyxDQUFDRSxPQUFWLENBQWtCLHNCQUFsQixFQUEyQyxLQUFJUixPQUFRLEdBQXZELENBQVo7O0VBQ0EsSUFBSSxDQUFDSyxJQUFJLENBQUNJLE9BQUwsQ0FBYSxTQUFiLENBQUwsRUFBOEI7SUFDMUJILFNBQVMsR0FBR0EsU0FBUyxDQUFDRSxPQUFWLENBQWtCLHFEQUFsQixFQUEwRSxLQUFJUixPQUFRLEdBQXRGLENBQVo7RUFDSDs7RUFDREUsRUFBRSxDQUFDUSxhQUFILENBQWlCTCxJQUFqQixFQUF1QkMsU0FBdkI7QUFDSCxDQVBEIn0=
\ No newline at end of file
diff --git a/dist/scripts/utils/addScript.js b/dist/scripts/utils/addScript.js
new file mode 100644
index 00000000..3e6b47e5
--- /dev/null
+++ b/dist/scripts/utils/addScript.js
@@ -0,0 +1,50 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = addScript;
+
+var _fs = _interopRequireDefault(require("fs"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function readJsonFile(jsonFilePath) {
+ try {
+ return JSON.parse(_fs.default.readFileSync(jsonFilePath, 'UTF-8'));
+ } catch (e) {
+ return false;
+ }
+}
+
+function writeJsonFile(jsonFilePath, jsonContents) {
+ try {
+ _fs.default.writeFileSync(jsonFilePath, JSON.stringify(jsonContents, null, 2));
+ } catch (e) {
+ return false;
+ }
+
+ return true;
+}
+
+function addScript(name, script, packageJsonPath, fail) {
+ const packageJson = readJsonFile(packageJsonPath);
+
+ if (!(packageJson && packageJson.name)) {
+ fail();
+ return;
+ }
+
+ if (!('scripts' in packageJson)) {
+ packageJson.scripts = {};
+ }
+
+ if (!(name in packageJson.scripts)) {
+ packageJson.scripts[name] = script;
+ }
+
+ if (!writeJsonFile(packageJsonPath, packageJson)) {
+ fail();
+ }
+}
+//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJyZWFkSnNvbkZpbGUiLCJqc29uRmlsZVBhdGgiLCJKU09OIiwicGFyc2UiLCJmcyIsInJlYWRGaWxlU3luYyIsImUiLCJ3cml0ZUpzb25GaWxlIiwianNvbkNvbnRlbnRzIiwid3JpdGVGaWxlU3luYyIsInN0cmluZ2lmeSIsImFkZFNjcmlwdCIsIm5hbWUiLCJzY3JpcHQiLCJwYWNrYWdlSnNvblBhdGgiLCJmYWlsIiwicGFja2FnZUpzb24iLCJzY3JpcHRzIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vbGliL3NjcmlwdHMvdXRpbHMvYWRkU2NyaXB0LmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBmcyBmcm9tICdmcyc7XG5cbmZ1bmN0aW9uIHJlYWRKc29uRmlsZShqc29uRmlsZVBhdGgpIHtcbiAgICB0cnkge1xuICAgICAgICByZXR1cm4gSlNPTi5wYXJzZShmcy5yZWFkRmlsZVN5bmMoanNvbkZpbGVQYXRoLCAnVVRGLTgnKSk7XG4gICAgfSBjYXRjaCAoZSkge1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxufVxuXG5mdW5jdGlvbiB3cml0ZUpzb25GaWxlKGpzb25GaWxlUGF0aCwganNvbkNvbnRlbnRzKSB7XG4gICAgdHJ5IHtcbiAgICAgICAgZnMud3JpdGVGaWxlU3luYyhqc29uRmlsZVBhdGgsIEpTT04uc3RyaW5naWZ5KGpzb25Db250ZW50cywgbnVsbCwgMikpO1xuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgICByZXR1cm4gdHJ1ZTtcbn1cblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gYWRkU2NyaXB0KG5hbWUsIHNjcmlwdCwgcGFja2FnZUpzb25QYXRoLCBmYWlsKSB7XG4gICAgY29uc3QgcGFja2FnZUpzb24gPSByZWFkSnNvbkZpbGUocGFja2FnZUpzb25QYXRoKTtcbiAgICBpZiAoIShwYWNrYWdlSnNvbiAmJiBwYWNrYWdlSnNvbi5uYW1lKSkge1xuICAgICAgICBmYWlsKCk7XG4gICAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBpZiAoISgnc2NyaXB0cycgaW4gcGFja2FnZUpzb24pKSB7XG4gICAgICAgIHBhY2thZ2VKc29uLnNjcmlwdHMgPSB7fTtcbiAgICB9XG5cbiAgICBpZiAoIShuYW1lIGluIHBhY2thZ2VKc29uLnNjcmlwdHMpKSB7XG4gICAgICAgIHBhY2thZ2VKc29uLnNjcmlwdHNbbmFtZV0gPSBzY3JpcHQ7XG4gICAgfVxuXG4gICAgaWYgKCF3cml0ZUpzb25GaWxlKHBhY2thZ2VKc29uUGF0aCwgcGFja2FnZUpzb24pKSB7XG4gICAgICAgIGZhaWwoKTtcbiAgICB9XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTs7OztBQUVBLFNBQVNBLFlBQVQsQ0FBc0JDLFlBQXRCLEVBQW9DO0VBQ2hDLElBQUk7SUFDQSxPQUFPQyxJQUFJLENBQUNDLEtBQUwsQ0FBV0MsV0FBQSxDQUFHQyxZQUFILENBQWdCSixZQUFoQixFQUE4QixPQUE5QixDQUFYLENBQVA7RUFDSCxDQUZELENBRUUsT0FBT0ssQ0FBUCxFQUFVO0lBQ1IsT0FBTyxLQUFQO0VBQ0g7QUFDSjs7QUFFRCxTQUFTQyxhQUFULENBQXVCTixZQUF2QixFQUFxQ08sWUFBckMsRUFBbUQ7RUFDL0MsSUFBSTtJQUNBSixXQUFBLENBQUdLLGFBQUgsQ0FBaUJSLFlBQWpCLEVBQStCQyxJQUFJLENBQUNRLFNBQUwsQ0FBZUYsWUFBZixFQUE2QixJQUE3QixFQUFtQyxDQUFuQyxDQUEvQjtFQUNILENBRkQsQ0FFRSxPQUFPRixDQUFQLEVBQVU7SUFDUixPQUFPLEtBQVA7RUFDSDs7RUFDRCxPQUFPLElBQVA7QUFDSDs7QUFFYyxTQUFTSyxTQUFULENBQW1CQyxJQUFuQixFQUF5QkMsTUFBekIsRUFBaUNDLGVBQWpDLEVBQWtEQyxJQUFsRCxFQUF3RDtFQUNuRSxNQUFNQyxXQUFXLEdBQUdoQixZQUFZLENBQUNjLGVBQUQsQ0FBaEM7O0VBQ0EsSUFBSSxFQUFFRSxXQUFXLElBQUlBLFdBQVcsQ0FBQ0osSUFBN0IsQ0FBSixFQUF3QztJQUNwQ0csSUFBSTtJQUNKO0VBQ0g7O0VBRUQsSUFBSSxFQUFFLGFBQWFDLFdBQWYsQ0FBSixFQUFpQztJQUM3QkEsV0FBVyxDQUFDQyxPQUFaLEdBQXNCLEVBQXRCO0VBQ0g7O0VBRUQsSUFBSSxFQUFFTCxJQUFJLElBQUlJLFdBQVcsQ0FBQ0MsT0FBdEIsQ0FBSixFQUFvQztJQUNoQ0QsV0FBVyxDQUFDQyxPQUFaLENBQW9CTCxJQUFwQixJQUE0QkMsTUFBNUI7RUFDSDs7RUFFRCxJQUFJLENBQUNOLGFBQWEsQ0FBQ08sZUFBRCxFQUFrQkUsV0FBbEIsQ0FBbEIsRUFBa0Q7SUFDOUNELElBQUk7RUFDUDtBQUNKIn0=
\ No newline at end of file
diff --git a/dist/skeletonDependencies.js b/dist/skeletonDependencies.js
new file mode 100644
index 00000000..31e6e13d
--- /dev/null
+++ b/dist/skeletonDependencies.js
@@ -0,0 +1,24 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = void 0;
+var _default = {
+ connect: '3.6.6',
+ 'server-destroy': '1.0.1',
+ winston: '2.3.0',
+ 'find-port': '2.0.1',
+ rimraf: '2.6.2',
+ shelljs: '0.7.5',
+ lodash: '4.17.15',
+ request: '2.88.0',
+ queue: '4.0.1',
+ reify: '0.17.3',
+ send: '0.16.2',
+ mime: '2.0.3',
+ 'fs-extra': '3.0.1',
+ 'fs-plus': '2.9.3'
+};
+exports.default = _default;
+//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjb25uZWN0Iiwid2luc3RvbiIsInJpbXJhZiIsInNoZWxsanMiLCJsb2Rhc2giLCJyZXF1ZXN0IiwicXVldWUiLCJyZWlmeSIsInNlbmQiLCJtaW1lIl0sInNvdXJjZXMiOlsiLi4vbGliL3NrZWxldG9uRGVwZW5kZW5jaWVzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBkZWZhdWx0IHtcbiAgICBjb25uZWN0OiAnMy42LjYnLFxuICAgICdzZXJ2ZXItZGVzdHJveSc6ICcxLjAuMScsXG4gICAgd2luc3RvbjogJzIuMy4wJyxcbiAgICAnZmluZC1wb3J0JzogJzIuMC4xJyxcbiAgICByaW1yYWY6ICcyLjYuMicsXG4gICAgc2hlbGxqczogJzAuNy41JyxcbiAgICBsb2Rhc2g6ICc0LjE3LjE1JyxcbiAgICByZXF1ZXN0OiAnMi44OC4wJyxcbiAgICBxdWV1ZTogJzQuMC4xJyxcbiAgICByZWlmeTogJzAuMTcuMycsXG4gICAgc2VuZDogJzAuMTYuMicsXG4gICAgbWltZTogJzIuMC4zJyxcbiAgICAnZnMtZXh0cmEnOiAnMy4wLjEnLFxuICAgICdmcy1wbHVzJzogJzIuOS4zJ1xufTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O2VBQWU7RUFDWEEsT0FBTyxFQUFFLE9BREU7RUFFWCxrQkFBa0IsT0FGUDtFQUdYQyxPQUFPLEVBQUUsT0FIRTtFQUlYLGFBQWEsT0FKRjtFQUtYQyxNQUFNLEVBQUUsT0FMRztFQU1YQyxPQUFPLEVBQUUsT0FORTtFQU9YQyxNQUFNLEVBQUUsU0FQRztFQVFYQyxPQUFPLEVBQUUsUUFSRTtFQVNYQyxLQUFLLEVBQUUsT0FUSTtFQVVYQyxLQUFLLEVBQUUsUUFWSTtFQVdYQyxJQUFJLEVBQUUsUUFYSztFQVlYQyxJQUFJLEVBQUUsT0FaSztFQWFYLFlBQVksT0FiRDtFQWNYLFdBQVc7QUFkQSxDIn0=
\ No newline at end of file
diff --git a/dist/utils.js b/dist/utils.js
new file mode 100644
index 00000000..f931f672
--- /dev/null
+++ b/dist/utils.js
@@ -0,0 +1,328 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.computeHashForHashesSet = computeHashForHashesSet;
+exports.default = void 0;
+exports.exists = exists;
+exports.getFileList = getFileList;
+exports.readAndGetFileHash = readAndGetFileHash;
+exports.readAndHashFiles = readAndHashFiles;
+exports.readDir = readDir;
+exports.readFilesAndComputeHash = readFilesAndComputeHash;
+exports.rmWithRetries = rmWithRetries;
+exports.symlinkExists = symlinkExists;
+
+var _path = _interopRequireDefault(require("path"));
+
+var _fs = _interopRequireDefault(require("fs"));
+
+var _crypto = _interopRequireDefault(require("crypto"));
+
+var _shelljs = _interopRequireDefault(require("shelljs"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/* eslint-disable consistent-return */
+
+/**
+ * Exists
+ * @param {string} pathToCheck
+ * @returns {boolean}
+ */
+function exists(pathToCheck) {
+ try {
+ _fs.default.accessSync(pathToCheck);
+
+ return true;
+ } catch (e) {
+ return false;
+ }
+}
+/**
+ * Simple wrapper for shelljs.rm with additional retries in case of failure.
+ * It is useful when something is concurrently reading the dir you want to remove.
+ */
+
+
+function rmWithRetries(...args) {
+ let retries = 0;
+ return new Promise((resolve, reject) => {
+ function rm(...rmArgs) {
+ try {
+ _shelljs.default.config.fatal = true;
+
+ _shelljs.default.rm(...rmArgs);
+
+ _shelljs.default.config.reset();
+
+ resolve();
+ } catch (e) {
+ retries += 1;
+
+ if (retries < 5) {
+ setTimeout(() => {
+ rm(...rmArgs);
+ }, 100);
+ } else {
+ _shelljs.default.config.reset();
+
+ reject(e);
+ }
+ }
+ }
+
+ rm(...args);
+ });
+}
+
+function readDir(dir, callback) {
+ if (!callback) {
+ return new Promise((resolve, reject) => {
+ readDir(dir, (err, data, stats) => {
+ if (err) {
+ reject(err);
+ } else {
+ resolve({
+ data,
+ stats
+ });
+ }
+ });
+ });
+ }
+
+ let list = [];
+ let allStats = {};
+
+ _fs.default.readdir(dir, (err, files) => {
+ if (err) {
+ return callback(err);
+ }
+
+ let pending = files.length;
+
+ if (!pending) {
+ return callback(null, list, allStats);
+ }
+
+ files.forEach(file => {
+ const filePath = _path.default.join(dir, file);
+
+ _fs.default.stat(filePath, (_err, stats) => {
+ if (_err) {
+ return callback(_err);
+ }
+
+ if (stats.isDirectory()) {
+ readDir(filePath, (__err, res, _allStats) => {
+ if (__err) {
+ return callback(__err);
+ }
+
+ list = list.concat(res);
+ allStats = Object.assign(allStats, _allStats);
+ pending -= 1;
+
+ if (!pending) {
+ return callback(null, list, allStats);
+ }
+ });
+ } else {
+ list.push(filePath);
+ allStats[filePath] = {
+ size: stats.size,
+ dates: [stats.birthtime.getTime(), stats.ctime.getTime(), stats.mtime.getTime()]
+ };
+ pending -= 1;
+
+ if (!pending) {
+ return callback(null, list, allStats);
+ }
+ }
+ });
+ });
+ });
+}
+/**
+ * Returns a file list from a directory.
+ * @param {string} dir - dir path
+ * @param {boolean} sort - whether to apply sort
+ * @returns {Promise}
+ */
+
+
+function getFileList(dir, sort = false) {
+ return new Promise((resolve, reject) => {
+ readDir(dir, (error, files) => {
+ if (error) {
+ reject(error);
+ return;
+ } // eslint-disable-next-line no-param-reassign
+
+
+ let resultantFilesList;
+
+ if (sort) {
+ const stripLength = dir.substr(0, 2) === './' ? dir.length - 1 : dir.length + 1;
+ let pathsUnified = files.map(pth => pth.substr(stripLength).replace(/[\\/]/gm, '-'));
+ const temporaryIndex = {};
+ files.forEach((file, i) => {
+ temporaryIndex[pathsUnified[i]] = file;
+ });
+ pathsUnified = pathsUnified.sort();
+ const filesSorted = [];
+ pathsUnified.forEach(key => {
+ filesSorted.push(temporaryIndex[key]);
+ });
+ resultantFilesList = filesSorted;
+ } else {
+ resultantFilesList = files;
+ }
+
+ resolve(resultantFilesList);
+ });
+ });
+}
+/**
+ * Returns file's hash.
+ * @param {string} file - file path
+ * @param {boolean} returnFileContents - include file contents in the resultant object
+ * @returns {Promise