UNPKG

sardines-compile-time-tools

Version:

sardines.compile-time-tools.js is part of the sardines.io project

316 lines (315 loc) 16 kB
"use strict"; 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 = {}));