2017-08-03 04:13:30 +08:00
|
|
|
#!/usr/bin/env node
|
|
|
|
/* eslint global-require: 0 */
|
|
|
|
/* eslint quote-props: 0 */
|
|
|
|
const path = require('path');
|
2017-08-13 10:34:24 +08:00
|
|
|
const https = require('https');
|
2017-08-11 13:47:06 +08:00
|
|
|
const fs = require('fs');
|
|
|
|
const rimraf = require('rimraf');
|
2017-10-24 01:51:32 +08:00
|
|
|
const targz = require('targz');
|
2017-10-03 13:18:06 +08:00
|
|
|
const { safeExec } = require('./utils/child-process-wrapper.js');
|
2017-08-03 04:13:30 +08:00
|
|
|
|
2017-09-02 14:22:35 +08:00
|
|
|
const npmElectronTarget = require('../package.json').devDependencies.electron;
|
2017-08-03 04:13:30 +08:00
|
|
|
const npmEnvs = {
|
|
|
|
system: process.env,
|
|
|
|
electron: Object.assign({}, process.env, {
|
2017-10-03 13:18:06 +08:00
|
|
|
npm_config_target: npmElectronTarget,
|
|
|
|
npm_config_arch: process.arch,
|
|
|
|
npm_config_target_arch: process.arch,
|
|
|
|
npm_config_disturl: 'https://atom.io/download/atom-shell',
|
|
|
|
npm_config_runtime: 'electron',
|
|
|
|
npm_config_build_from_source: true,
|
2017-08-03 04:13:30 +08:00
|
|
|
}),
|
|
|
|
};
|
|
|
|
|
|
|
|
function npm(cmd, options) {
|
2017-10-03 13:18:06 +08:00
|
|
|
const { cwd, env } = Object.assign({ cwd: '.', env: 'system' }, options);
|
2017-08-03 04:13:30 +08:00
|
|
|
|
|
|
|
return new Promise((resolve, reject) => {
|
2017-10-03 13:18:06 +08:00
|
|
|
console.log(`\n-- Running npm ${cmd} in ${cwd} with ${env} config --`);
|
2017-08-03 04:13:30 +08:00
|
|
|
|
2017-10-03 13:18:06 +08:00
|
|
|
safeExec(
|
|
|
|
`npm ${cmd}`,
|
|
|
|
{
|
|
|
|
cwd: path.resolve(__dirname, '..', cwd),
|
|
|
|
env: npmEnvs[env],
|
|
|
|
},
|
|
|
|
err => {
|
|
|
|
return err ? reject(err) : resolve(null);
|
|
|
|
}
|
|
|
|
);
|
2017-08-03 04:13:30 +08:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2017-08-13 10:34:24 +08:00
|
|
|
function downloadMailsync() {
|
2017-10-31 03:51:08 +08:00
|
|
|
https.get(`https://mailspring-builds.s3.amazonaws.com/stable.txt`, response => {
|
|
|
|
let data = '';
|
|
|
|
response.on('data', d => {
|
|
|
|
data += d;
|
|
|
|
});
|
|
|
|
response.on('end', () => {
|
|
|
|
const head = data.split('-').pop();
|
|
|
|
const distKey = `${process.platform}-${process.arch}`;
|
|
|
|
const distDir = {
|
|
|
|
'darwin-x64': 'osx',
|
|
|
|
'win32-x64': 'win-ia32', // serve 32-bit since backwards compatibility is great
|
|
|
|
'win32-ia32': 'win-ia32',
|
|
|
|
'linux-x64': 'linux',
|
|
|
|
'linux-ia32': null,
|
|
|
|
}[distKey];
|
2017-08-13 10:34:24 +08:00
|
|
|
|
2017-10-31 03:51:08 +08:00
|
|
|
if (!distDir) {
|
2017-10-03 13:18:06 +08:00
|
|
|
console.error(
|
2017-10-31 03:51:08 +08:00
|
|
|
`\nSorry, a Mailspring Mailsync build for your machine (${distKey}) is not yet available.`
|
2017-10-03 13:18:06 +08:00
|
|
|
);
|
2017-10-31 03:51:08 +08:00
|
|
|
return;
|
2017-08-13 10:34:24 +08:00
|
|
|
}
|
2017-10-31 03:51:08 +08:00
|
|
|
|
|
|
|
const distS3URL = `https://mailspring-builds.s3.amazonaws.com/client/${head}/${distDir}/mailsync.tar.gz`;
|
|
|
|
https.get(distS3URL, response => {
|
|
|
|
if (response.statusCode === 200) {
|
|
|
|
response.pipe(fs.createWriteStream(`app/mailsync.tar.gz`));
|
|
|
|
response.on('end', () => {
|
|
|
|
console.log(`\nDownloaded Mailsync build ${distDir}-${head} to ./app/mailsync.tar.gz.`);
|
|
|
|
targz.decompress(
|
|
|
|
{
|
|
|
|
src: `app/mailsync.tar.gz`,
|
|
|
|
dest: 'app/',
|
|
|
|
},
|
|
|
|
err => {
|
|
|
|
if (!err) {
|
|
|
|
console.log(`\nUnpackaged Mailsync build.`);
|
|
|
|
} else {
|
|
|
|
console.error(`\nEncountered an error unpacking: ${err}`);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
console.error(
|
|
|
|
`Sorry, an error occurred while fetching the Mailspring Mailsync build for your machine\n(${distS3URL})\n`
|
|
|
|
);
|
|
|
|
response.pipe(process.stderr);
|
|
|
|
response.on('end', () => console.error('\n'));
|
|
|
|
}
|
|
|
|
});
|
2017-08-13 10:34:24 +08:00
|
|
|
});
|
2017-10-03 13:18:06 +08:00
|
|
|
});
|
2017-08-13 10:34:24 +08:00
|
|
|
}
|
|
|
|
|
2017-08-11 14:20:34 +08:00
|
|
|
// For speed, we cache app/node_modules. However, we need to
|
|
|
|
// be sure to do a full rebuild of native node modules when the
|
|
|
|
// Electron version changes. To do this we check a marker file.
|
2017-08-11 14:31:37 +08:00
|
|
|
const appModulesPath = path.resolve(__dirname, '..', 'app', 'node_modules');
|
|
|
|
const cacheVersionPath = path.join(appModulesPath, '.postinstall-target-version');
|
2017-10-03 13:18:06 +08:00
|
|
|
const cacheElectronTarget =
|
|
|
|
fs.existsSync(cacheVersionPath) && fs.readFileSync(cacheVersionPath).toString();
|
2017-08-11 14:20:34 +08:00
|
|
|
|
|
|
|
if (cacheElectronTarget !== npmElectronTarget) {
|
2017-10-03 13:18:06 +08:00
|
|
|
console.log(`\n-- Clearing app/node_modules --`);
|
2017-08-11 14:31:37 +08:00
|
|
|
rimraf.sync(appModulesPath);
|
2017-08-11 13:47:06 +08:00
|
|
|
}
|
|
|
|
|
2017-08-11 14:20:34 +08:00
|
|
|
// run `npm install` in ./app with Electron NPM config
|
2017-10-03 13:18:06 +08:00
|
|
|
npm('install', { cwd: './app', env: 'electron' }).then(() => {
|
2017-08-11 14:20:34 +08:00
|
|
|
// run `npm dedupe` in ./app with Electron NPM config
|
2017-10-03 13:18:06 +08:00
|
|
|
npm('dedupe', { cwd: './app', env: 'electron' }).then(() => {
|
2018-01-21 11:57:52 +08:00
|
|
|
// run `npm ls` in ./app - detects missing peer dependencies, etc.
|
|
|
|
npm('ls', { cwd: './app', env: 'electron' }).then(() => {
|
|
|
|
// write the marker with the electron version
|
|
|
|
fs.writeFileSync(cacheVersionPath, npmElectronTarget);
|
2017-08-13 10:34:24 +08:00
|
|
|
|
2018-01-21 11:57:52 +08:00
|
|
|
// if the user hasn't cloned the private mailsync module, download
|
|
|
|
// the binary for their operating system that was shipped to S3.
|
|
|
|
if (!fs.existsSync('./mailsync/build.sh')) {
|
|
|
|
console.log(`\n-- Downloading the last released version of Mailspring mailsync --`);
|
|
|
|
downloadMailsync();
|
|
|
|
}
|
|
|
|
});
|
2017-08-13 10:34:24 +08:00
|
|
|
});
|
|
|
|
});
|