sardines-compile-time-tools
Version:
sardines.compile-time-tools.js is part of the sardines.io project
316 lines (315 loc) • 16 kB
JavaScript
;
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
var __generator = (this && this.__generator) || function (thisArg, body) {
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
function verb(n) { return function (v) { return step([n, v]); }; }
function step(op) {
if (f) throw new TypeError("Generator is already executing.");
while (_) try {
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
if (y = 0, t) op = [op[0] & 2, t.value];
switch (op[0]) {
case 0: case 1: t = op; break;
case 4: _.label++; return { value: op[1], done: false };
case 5: _.label++; y = op[1]; op = [0]; continue;
case 7: op = _.ops.pop(); _.trys.pop(); continue;
default:
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
if (t[2]) _.ops.pop();
_.trys.pop(); continue;
}
op = body.call(thisArg, _);
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
}
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.Source = void 0;
var npm = require("npm");
var sardines_core_1 = require("sardines-core");
var sardines_core_2 = require("sardines-core");
var fs = require("fs");
var path = require("path");
var git = require("simple-git/promise");
var child_process_1 = require("child_process");
var util_1 = require("util");
var execAsync = util_1.promisify(child_process_1.exec);
var Source;
(function (Source) {
var _this = this;
Source.execCmd = function (cmd) {
return __awaiter(this, void 0, void 0, function () {
var _a, stdout, stderr;
return __generator(this, function (_b) {
switch (_b.label) {
case 0: return [4, execAsync(cmd)];
case 1:
_a = _b.sent(), stdout = _a.stdout, stderr = _a.stderr;
if (stderr)
throw stderr;
return [2, stdout];
}
});
});
};
var npmInst = null;
Source.npmCmd = function (command, args) {
return new Promise(function (resolve, reject) {
var cmd = function () {
(npmInst.commands)[command](args, function (err, data) {
if (err) {
reject(err);
}
else {
resolve(data);
}
});
};
if (!npmInst) {
npm.load(function (err, inst) {
if (err)
reject(err);
else {
npmInst = inst;
cmd();
}
});
}
else {
cmd();
}
});
};
Source.requirePackage = function (packName) { return __awaiter(_this, void 0, void 0, function () {
var packageDir, packageConfigFile, packageConfig, mainFileName, mainFilePath, packageInst;
return __generator(this, function (_a) {
packageDir = path.resolve("node_modules/" + packName);
if (!fs.existsSync(packageDir)) {
throw "Can not access package [" + packName + "] directory at [" + packageDir + "]";
}
packageConfigFile = path.resolve(packageDir + "/package.json");
if (!fs.existsSync(packageConfigFile)) {
throw "Can not access package.json file for package [" + packName + "] at [" + packageConfigFile + "]";
}
packageConfig = null;
try {
packageConfig = JSON.parse(fs.readFileSync(packageConfigFile).toString());
if (!packageConfig)
throw '';
}
catch (e) {
throw "Can not parse package.json file for package [" + packName + "]";
}
if (packageConfig && !packageConfig.main) {
throw "Invalid package.json file for package [" + packName + "]";
}
mainFileName = packageConfig.main;
mainFilePath = path.resolve(packageDir + "/" + mainFileName);
if (!fs.existsSync(mainFilePath)) {
throw "Can not access entrance file for package [" + packName + "] at [" + mainFilePath + "]";
}
packageInst = require(mainFilePath);
if (packageInst)
return [2, packageInst];
else {
throw sardines_core_2.utils.unifyErrMesg("Invalid package [" + packName + "]", 'sourcing', 'npm');
}
return [2];
});
}); };
Source.getPackageFromNpm = function (packName, locationType, verbose) {
if (verbose === void 0) { verbose = false; }
return __awaiter(_this, void 0, void 0, function () {
var type, _a, e_1, e_2;
return __generator(this, function (_b) {
switch (_b.label) {
case 0:
if (!!fs.existsSync("node_modules/" + packName)) return [3, 10];
_b.label = 1;
case 1:
_b.trys.push([1, 9, , 10]);
type = locationType || sardines_core_1.Sardines.LocationType.npm;
_a = type;
switch (_a) {
case sardines_core_1.Sardines.LocationType.npm: return [3, 2];
case sardines_core_1.Sardines.LocationType.npm_link: return [3, 4];
case sardines_core_1.Sardines.LocationType.file: return [3, 6];
}
return [3, 7];
case 2:
if (verbose) {
console.log('going to install package:', packName);
}
return [4, Source.npmCmd('install', [packName])];
case 3:
_b.sent();
if (verbose) {
console.log('package:', packName, 'installed');
}
return [3, 8];
case 4:
if (verbose) {
console.log('going to link package:', packName);
}
return [4, Source.npmCmd('link', [packName])];
case 5:
_b.sent();
if (verbose) {
console.log('package:', packName, 'linked');
}
return [3, 8];
case 6: return [3, 8];
case 7: return [3, 8];
case 8: return [3, 10];
case 9:
e_1 = _b.sent();
if (verbose) {
console.error("ERROR when downloading npm package [" + packName + "]");
}
throw sardines_core_2.utils.unifyErrMesg("Error when downloading npm package [" + packName + "]: " + e_1, 'sourcing', 'npm');
case 10:
_b.trys.push([10, 12, , 13]);
return [4, Source.requirePackage(packName)];
case 11: return [2, _b.sent()];
case 12:
e_2 = _b.sent();
if (verbose) {
console.error("ERROR when importing npm package [" + packName + "]");
}
throw sardines_core_2.utils.unifyErrMesg("Error when importing npm package [" + packName + "]: " + e_2, 'sourcing', 'npm');
case 13: return [2];
}
});
});
};
Source.getMainFilePathOfPackage = function (packageName, nodeModulesDir, targetDir) {
var filepath = '';
if (!packageName || !nodeModulesDir || !targetDir)
return filepath;
var packageJsonFilepath = path.resolve(nodeModulesDir, "./" + packageName + "/package.json");
if (!fs.existsSync(packageJsonFilepath))
return filepath;
try {
var packageJson = JSON.parse(fs.readFileSync(packageJsonFilepath).toString());
if (!packageJson || !packageJson.main || typeof packageJson.main !== 'string') {
throw 'Invalid package.json file, or invalid main section in it';
}
var mainfilepath = path.resolve(nodeModulesDir, './' + packageName + '/' + packageJson.main);
filepath = path.relative(targetDir, mainfilepath);
}
catch (e) {
console.error('ERROR while tring to find package main file of package:', packageName, ', in node_modules:', nodeModulesDir, ', error:', e);
}
return filepath;
};
Source.getSourceFromGit = function (gitUrl, baseDir, options) {
if (options === void 0) { options = {}; }
return __awaiter(_this, void 0, void 0, function () {
var workRoot, urlParts, repoName, repoNameParts, appName, version, workDir, checkoutStr, cmd, stdout, e_3, e_4;
return __generator(this, function (_a) {
switch (_a.label) {
case 0:
if (!gitUrl) {
throw sardines_core_2.utils.unifyErrMesg("Empty git url", 'sourcing', 'git');
}
workRoot = baseDir ? baseDir : './';
urlParts = gitUrl.split('/');
repoName = '';
if (urlParts.length > 1) {
repoName = urlParts[urlParts.length - 1];
repoNameParts = repoName.split('.');
if (repoNameParts.length > 1 && repoNameParts[repoNameParts.length - 1].toLowerCase() === 'git') {
repoNameParts.pop();
repoName = repoNameParts.join('.');
}
else {
repoName = '';
}
}
if (!repoName) {
throw sardines_core_2.utils.unifyErrMesg("Invalid git url: can not parse repository name", 'sourcing', 'git');
}
appName = (options && options.application) ? options.application : repoName;
version = (options && options.version) ? options.version : '*';
workRoot = path.resolve(workRoot + '/', "./" + appName + "/" + version + "/");
workDir = path.resolve(workRoot + "/", "./" + repoName);
if (fs.existsSync(workDir)) {
if (options && options.initWorkDir) {
fs.rmdirSync(workDir, { recursive: true });
}
else {
return [2, workDir];
}
}
if (!fs.existsSync(workRoot)) {
fs.mkdirSync(workRoot, { recursive: true });
}
_a.label = 1;
case 1:
_a.trys.push([1, 8, , 9]);
if (options && options.verbose) {
console.log("[source] going to git clone [" + appName + "@" + version + "] under dir " + workRoot + "...");
}
return [4, git(workRoot).clone(gitUrl)];
case 2:
_a.sent();
if (!fs.existsSync(workDir)) {
throw "git repository did not cloned to desired directory [" + workDir + "]";
}
checkoutStr = '';
if (options && options.version)
checkoutStr = "sardines-v" + options.version;
else if (options && options.branch)
checkoutStr = options.branch;
else if (options && options.tag)
checkoutStr = options.tag;
if (!checkoutStr)
checkoutStr = 'master';
return [4, git(workDir).checkout(checkoutStr)];
case 3:
_a.sent();
if (options && options.verbose) {
console.log("[source] source code of [" + appName + "@" + version + "] has been cloned and checked out");
}
if (options && options.verbose) {
console.log("[source] going to install node modules of [" + appName + "@" + version + "]...");
}
cmd = "cd " + workDir + " && npm i && npm uninstall sardines-core && rm -rf node_modules/sardines-core";
_a.label = 4;
case 4:
_a.trys.push([4, 6, , 7]);
return [4, Source.execCmd(cmd)];
case 5:
stdout = _a.sent();
if (options && options.verbose) {
console.log("[source] node modules of [" + appName + "@" + version + "] have been installed using command [" + cmd + "]:", stdout);
}
return [3, 7];
case 6:
e_3 = _a.sent();
if (options && options.verbose) {
console.error("[source] Error when installing node modules of [" + appName + "@" + version + "] using command [" + cmd + "]:", e_3);
}
return [3, 7];
case 7: return [3, 9];
case 8:
e_4 = _a.sent();
throw sardines_core_2.utils.unifyErrMesg(e_4, 'sourcing', 'git');
case 9: return [2, workDir];
}
});
});
};
})(Source = exports.Source || (exports.Source = {}));