embark/lib/utils/utils.js

224 lines
5.2 KiB
JavaScript
Raw Normal View History

let path = require('path');
let globule = require('globule');
let merge = require('merge');
let http = require('follow-redirects').http;
let https = require('follow-redirects').https;
let shelljs = require('shelljs');
2017-12-16 12:23:02 -05:00
var tar = require('tar');
2017-12-19 14:07:48 -05:00
var propose = require('propose');
2018-05-18 16:51:03 -04:00
var Web3 = require('web3');
const constants = require('../constants');
2017-02-18 14:10:01 -05:00
2017-12-15 21:53:11 -05:00
//let fs = require('../core/fs.js');
let o_fs = require('fs-extra');
2017-02-18 14:10:01 -05:00
function joinPath() {
return path.join.apply(path.join, arguments);
}
2017-02-18 14:45:57 -05:00
function filesMatchingPattern(files) {
2017-02-19 00:00:01 -05:00
return globule.find(files, {nonull: true});
2017-02-18 14:37:07 -05:00
}
function fileMatchesPattern(patterns, intendedPath) {
2017-02-19 00:00:01 -05:00
return globule.isMatch(patterns, intendedPath);
2017-02-18 14:37:07 -05:00
}
2017-02-18 14:45:57 -05:00
function recursiveMerge(target, source) {
return merge.recursive(target, source);
}
2017-02-18 15:27:08 -05:00
function checkIsAvailable(url, callback) {
2017-12-05 18:14:46 -05:00
http.get(url, function (_res) {
callback(true);
2017-12-05 18:14:46 -05:00
}).on('error', function (_res) {
callback(false);
2017-02-18 15:27:08 -05:00
});
}
2017-12-15 22:15:24 -05:00
function httpGetRequest(httpObj, url, callback) {
httpObj.get(url, function(res) {
2017-12-15 22:11:55 -05:00
let body = '';
res.on('data', function (d) {
body += d;
});
res.on('end', function () {
callback(null, body);
});
}).on('error', function (err) {
callback(err);
2017-12-15 22:11:55 -05:00
});
2017-04-02 14:40:10 -04:00
}
2017-12-15 22:15:24 -05:00
function httpGet(url, callback) {
httpGetRequest(http, url, callback);
}
function httpsGet(url, callback) {
2017-12-15 22:15:24 -05:00
httpGetRequest(https, url, callback);
}
2017-12-30 21:44:59 -05:00
function httpGetJson(url, callback) {
httpGetRequest(http, url, function(err, body) {
try {
let parsed = JSON.parse(body);
return callback(err, parsed);
} catch(e) {
return callback(e);
}
});
}
function runCmd(cmd, options) {
let result = shelljs.exec(cmd, options || {silent: true});
if (result.code !== 0) {
console.log("error doing.. " + cmd);
console.log(result.output);
if (result.stderr !== undefined) {
console.log(result.stderr);
}
exit();
}
}
function cd(folder) {
shelljs.cd(folder);
}
function sed(file, pattern, replace) {
shelljs.sed('-i', pattern, replace, file);
}
function exit(code) {
process.exit(code);
}
2017-12-15 21:53:11 -05:00
function downloadFile(url, dest, cb) {
var file = o_fs.createWriteStream(dest);
(url.substring(0,5) === 'https' ? https : http).get(url, function(response) {
response.pipe(file);
file.on('finish', function() {
file.close(cb);
});
}).on('error', function(err) {
o_fs.unlink(dest);
if (cb) cb(err.message);
});
}
2017-12-16 12:23:02 -05:00
function extractTar(filename, packageDirectory, cb) {
o_fs.createReadStream(filename).pipe(
tar.x({
strip: 1,
C: packageDirectory
}).on('end', function() {
cb();
})
);
}
2017-12-19 14:07:48 -05:00
function proposeAlternative(word, _dictionary, _exceptions) {
let exceptions = _exceptions || [];
let dictionary = _dictionary.filter((entry) => {
return exceptions.indexOf(entry) < 0;
});
return propose(word, dictionary, {threshold: 0.3});
}
function pwd() {
2018-03-26 15:26:37 -04:00
return process.env.PWD || process.cwd();
}
function getExternalContractUrl(file) {
let url;
const RAW_URL = 'https://raw.githubusercontent.com/';
const MALFORMED_ERROR = 'Malformed Github URL for ';
if (file.startsWith('https://github')) {
const match = file.match(/https:\/\/github\.[a-z]+\/(.*)/);
if (!match) {
console.error(MALFORMED_ERROR + file);
return null;
}
url = `${RAW_URL}${match[1].replace('blob/', '')}`;
} else if (file.startsWith('git')) {
// Match values
// [0] entire input
// [1] git://
// [2] user
// [3] repository
// [4] path
// [5] branch
const match = file.match(
2018-04-20 12:04:27 -04:00
/(git:\/\/)?github\.[a-z]+\/([-a-zA-Z0-9@:%_+.~#?&=]+)\/([-a-zA-Z0-9@:%_+.~#?&=]+)\/([-a-zA-Z0-9@:%_+.~?\/&=]+)#?([a-zA-Z0-1\/_.-]*)?/
);
if (!match) {
console.error(MALFORMED_ERROR + file);
return null;
}
let branch = match[5];
if (!branch) {
branch = 'master';
}
url = `${RAW_URL}${match[2]}/${match[3]}/${branch}/${match[4]}`;
} else if (file.startsWith('http')) {
url = file;
} else {
return null;
}
const match = url.match(
2018-04-20 12:04:27 -04:00
/\.[a-z]+\/([-a-zA-Z0-9@:%_+.~#?&\/=]+)/
);
return {
url,
filePath: constants.httpContractsDirectory + match[1]
};
}
2018-05-18 16:51:03 -04:00
function toChecksumAddress(address) {
return Web3.utils.toChecksumAddress(address);
}
function sha3(arg) {
return Web3.utils.sha3(arg);
}
function normalizeInput(input) {
let args = Object.values(input);
if (args.length === 0) {
return "";
}
if (args.length === 1) {
if (Array.isArray(args[0])) { return args[0].join(','); }
return args[0] || "";
}
return ('[' + args.map((x) => {
if (x === null) { return "null"; }
if (x === undefined) { return "undefined"; }
if (Array.isArray(x)) { return x.join(','); }
return x;
}).toString() + ']');
}
2017-02-18 14:10:01 -05:00
module.exports = {
2017-02-18 14:45:57 -05:00
joinPath: joinPath,
filesMatchingPattern: filesMatchingPattern,
fileMatchesPattern: fileMatchesPattern,
2017-02-18 15:27:08 -05:00
recursiveMerge: recursiveMerge,
checkIsAvailable: checkIsAvailable,
2017-04-02 14:40:10 -04:00
httpGet: httpGet,
httpsGet: httpsGet,
2017-12-30 21:44:59 -05:00
httpGetJson: httpGetJson,
runCmd: runCmd,
cd: cd,
sed: sed,
2017-12-15 21:53:11 -05:00
exit: exit,
2017-12-16 12:23:02 -05:00
downloadFile: downloadFile,
2017-12-19 14:07:48 -05:00
extractTar: extractTar,
proposeAlternative: proposeAlternative,
pwd: pwd,
2018-05-18 16:51:03 -04:00
getExternalContractUrl,
toChecksumAddress: toChecksumAddress,
sha3: sha3,
normalizeInput
2017-02-18 14:10:01 -05:00
};