UNPKG

@jovian/type-tools

Version:

TypeTools is a Typescript library for providing extensible tooling runtime validations and type helpers.

162 lines 8.29 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 (g && (g = 0, op[0] && (_ = 0)), _) 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.SecretManager = void 0; var globals_ix_1 = require("../../src/common/globals.ix"); var destor_client_1 = require("../http/destor/destor.client"); var SecretManager; (function (SecretManager) { function resolve(obj, destorClient) { var _this = this; return (0, globals_ix_1.promise)(function (resolve, reject) { return __awaiter(_this, void 0, void 0, function () { var client, _a, list, targetsList, resolvedMap, _i, list_1, targetInfo, resolvedInfo, text, _b, _c, targetStub, stub, resolvedInfo, value; return __generator(this, function (_d) { switch (_d.label) { case 0: if (obj && typeof obj === 'object') { obj = (0, globals_ix_1.deepCopy)(obj); } if (!destorClient) return [3, 1]; _a = destorClient; return [3, 3]; case 1: return [4, (0, destor_client_1.getDestorClient)()]; case 2: _a = _d.sent(); _d.label = 3; case 3: client = _a; list = getResolvableWithinObject(obj); targetsList = [].concat.apply([], list.map(function (a) { return a.targets; })); return [4, client.resolve(targetsList)]; case 4: resolvedMap = _d.sent(); for (_i = 0, list_1 = list; _i < list_1.length; _i++) { targetInfo = list_1[_i]; if (targetInfo.targets.length === 1 && targetInfo.content === "<".concat(targetInfo.targets[0], ">")) { resolvedInfo = resolvedMap[targetInfo.targets[0]]; if (!resolvedInfo || resolvedInfo.error) { continue; } if (targetInfo.parent) { targetInfo.parent[targetInfo.index] = resolvedInfo.value; } else { obj = resolvedInfo.value; } continue; } text = targetInfo.content; for (_b = 0, _c = targetInfo.targets; _b < _c.length; _b++) { targetStub = _c[_b]; stub = "<".concat(targetStub, ">"); resolvedInfo = resolvedMap[targetStub]; if (!resolvedInfo || resolvedInfo.error) { continue; } try { value = ['string', 'number', 'boolean'].indexOf(typeof resolvedInfo.value) >= 0 ? resolvedInfo.value + '' : JSON.stringify(resolvedInfo.value); while (text.indexOf(stub) >= 0) { text = text.replace(stub, value); } } catch (e) { continue; } } if (targetInfo.parent) { targetInfo.parent[targetInfo.index] = text; } else { obj = text; } } resolve(obj); return [2]; } }); }); }); } SecretManager.resolve = resolve; })(SecretManager = exports.SecretManager || (exports.SecretManager = {})); function getResolvableWithinObject(obj, parent, index, collector) { if (collector === void 0) { collector = []; } var objtype = typeof obj; if (obj && objtype === 'object') { if (Array.isArray(obj)) { for (var i = 0; i < obj.length; ++i) { getResolvableWithinObject(obj[i], obj, i, collector); } } else { for (var _i = 0, _a = Object.keys(obj); _i < _a.length; _i++) { var prop = _a[_i]; getResolvableWithinObject(obj[prop], obj, prop, collector); } } } else if (objtype === 'string') { var str = obj; if (str.indexOf('<config.') >= 0 || str.indexOf('<secret.') >= 0) { collector.push({ content: str, parent: parent, index: index, targets: extractResolvableString(str) }); } } return collector; } function extractResolvableString(content) { var idx = 0; var targets = []; while (true) { var configPos = content.indexOf('<config.', idx); var secretPos = content.indexOf('<secret.', idx); if (configPos === -1 && secretPos === -1) { return targets; } if (configPos > secretPos) { var enderPos = content.indexOf('>', configPos); targets.push(content.slice(configPos + 1, enderPos)); idx = enderPos + 1; } else { var enderPos = content.indexOf('>', secretPos); targets.push(content.slice(secretPos + 1, enderPos)); idx = enderPos + 1; } } } //# sourceMappingURL=secret-resolver.js.map