UNPKG

tsioc

Version:

tsioc is AOP, Ioc container, via typescript decorator

176 lines (174 loc) 9.01 kB
"use strict"; var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { 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) : new P(function (resolve) { resolve(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 = y[op[0] & 2 ? "return" : op[0] ? "throw" : "next"]) && !(t = t.call(y, op[1])).done) return t; if (y = 0, t) op = [0, 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 }); var index_1 = require("./actions/index"); var index_2 = require("../utils/index"); var index_3 = require("./factories/index"); var index_4 = require("./decorators/index"); var MethodAccessor = /** @class */ (function () { function MethodAccessor(container) { this.container = container; } MethodAccessor.prototype.getMatcher = function () { return this.container.get(index_2.symbols.IProviderMatcher); }; MethodAccessor.prototype.invoke = function (token, propertyKey, target) { var providers = []; for (var _i = 3; _i < arguments.length; _i++) { providers[_i - 3] = arguments[_i]; } return __awaiter(this, void 0, void 0, function () { var targetClass, actionData, lifeScope, parameters, paramInstances, _a; return __generator(this, function (_b) { switch (_b.label) { case 0: if (!target) { target = (_a = this.container).resolve.apply(_a, [token].concat(providers)); } targetClass = this.container.getTokenImpl(token); if (!targetClass) { throw Error(token.toString() + ' is not implements by any class.'); } if (!(target && index_2.isFunction(target[propertyKey]))) return [3 /*break*/, 2]; actionData = { target: target, targetType: targetClass, propertyKey: propertyKey, }; lifeScope = this.container.getLifeScope(); lifeScope.execute(index_3.DecoratorType.Parameter, actionData, index_1.CoreActions.bindParameterProviders); providers = providers.concat(actionData.execResult); parameters = lifeScope.getMethodParameters(targetClass, target, propertyKey); return [4 /*yield*/, this.createParams.apply(this, [parameters].concat(providers))]; case 1: paramInstances = _b.sent(); return [2 /*return*/, target[propertyKey].apply(target, paramInstances)]; case 2: throw new Error("type: " + targetClass + " has no method " + propertyKey + "."); case 3: return [2 /*return*/]; } }); }); }; MethodAccessor.prototype.syncInvoke = function (token, propertyKey, target) { var providers = []; for (var _i = 3; _i < arguments.length; _i++) { providers[_i - 3] = arguments[_i]; } if (!target) { target = (_a = this.container).resolve.apply(_a, [token].concat(providers)); } var targetClass = this.container.getTokenImpl(token); if (!targetClass) { throw Error(token.toString() + ' is not implements by any class.'); } if (target && index_2.isFunction(target[propertyKey])) { var actionData = { target: target, targetType: targetClass, propertyKey: propertyKey, }; var lifeScope = this.container.getLifeScope(); lifeScope.execute(index_3.DecoratorType.Parameter, actionData, index_1.CoreActions.bindParameterProviders); providers = providers.concat(actionData.execResult); var parameters = lifeScope.getMethodParameters(targetClass, target, propertyKey); var paramInstances = this.createSyncParams.apply(this, [parameters].concat(providers)); return target[propertyKey].apply(target, paramInstances); } else { throw new Error("type: " + targetClass + " has no method " + propertyKey + "."); } var _a; }; MethodAccessor.prototype.createSyncParams = function (params) { var _this = this; var providers = []; for (var _i = 1; _i < arguments.length; _i++) { providers[_i - 1] = arguments[_i]; } var providerMap = (_a = this.getMatcher()).matchProviders.apply(_a, [params].concat(providers)); return params.map(function (param, index) { if (param.name && providerMap.has(param.name)) { return providerMap.resolve(param.name); } else if (index_2.isToken(param.type)) { return (_a = _this.container).resolve.apply(_a, [param.type].concat(providers)); } else { return undefined; } var _a; }); var _a; }; MethodAccessor.prototype.createParams = function (params) { var _this = this; var providers = []; for (var _i = 1; _i < arguments.length; _i++) { providers[_i - 1] = arguments[_i]; } var providerMap = (_a = this.getMatcher()).matchProviders.apply(_a, [params].concat(providers)); return Promise.all(params.map(function (param, index) { if (param.name && providerMap.has(param.name)) { return providerMap.resolve(param.name); } else if (index_2.isToken(param.type)) { return (_a = _this.container).resolve.apply(_a, [param.type].concat(providers)); } else { return undefined; } var _a; })); var _a; }; MethodAccessor = __decorate([ index_4.NonePointcut(), __metadata("design:paramtypes", [Object]) ], MethodAccessor); return MethodAccessor; }()); exports.MethodAccessor = MethodAccessor; //# sourceMappingURL=../sourcemaps/core/MethodAccessor.js.map